当前位置: 首页 > 知识库问答 >
问题:

从jsp视图中删除。删除表的行时无法获取表id

卢黎明
2023-03-14

我的任务:我必须从jsp视图中删除对表“testtable”的每一行操作。

后端MySQL:=我有两个表一个“userinfo”用于aurtherntication,另一个表“testtable”。

对于两个表连接,我使用了jsp中的隐藏字段输入,而不是使用外键关系。

在控制台打印中,我们可以在单击delete按钮后看到com.mysql.jdbc.jdbc4PreparedStatement@1f4bcaf:delete from testtable,其中id=0和email='myswagt@yahoo.com'在home servlet userid为0

下面请根据jsp、servlet、model、jdbc的帖子帮助我:

//费用模型

package com.intermediateDemo.home.dto;
public class ItemBean {
private  int id;
private  String email;
private String itemName;
private Double itemPrice;
private String transactionTime;
private  int userid;

public ItemBean() {
}
public ItemBean(int id, String email, String itemName, Double itemPrice, String    transactionTime) {
    this.id = id;
    this.itemName = itemName;
    this.itemPrice = itemPrice;
    this.transactionTime = transactionTime;
    this.email = email;
}
public String toString() {


    StringBuilder stringBuilder = new StringBuilder();
    stringBuilder.append("\n----------------------------------------------------------------------------------------------\n");
    stringBuilder.append("Id: " + id);
    //stringBuilder.append("\tName: " + firstName + ' ' + middleName + ' ' + lastName);
    stringBuilder.append("\titemname: " + itemName);
    stringBuilder.append("\titemprice: " + itemPrice);

    stringBuilder.append("\ttime: " + transactionTime);
       stringBuilder.append("\n----------------------------------------------------------------------------------------------\n");

    return stringBuilder.toString();

}

public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}
public int getUserid() {
    return userid;
}

public void setUserid(int userid) {
    this.userid = userid;
}

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getItemName() {
    return itemName;
}

public void setItemName(String itemName) {
    this.itemName = itemName;
}

public Double getItemPrice() {
    return itemPrice;
}

public void setItemPrice(Double itemPrice) {
    this.itemPrice = itemPrice;
}

public String getTransactionTime() {
    return transactionTime;
}

public void setTransactionTime(String transactionTime) {
    this.transactionTime = transactionTime;
}
}

//用户模型

package com.intermediateDemo.login.dto;
public class LoginBean {

private int userid;
private String email;
private String password;
public boolean valid;
private String lastName;
private String firstName;

public LoginBean() {
}

public LoginBean(String email, String lastname, String firstname) {
    this.email = email;
    this.firstName = firstname;
    this.lastName = lastname;

}

public int getUserid() {
    return userid;
}

public void setUserid(int userid) {
    this.userid = userid;
}

public String getPassword() {
    return password;
}

public void setPassword(String password) {
    this.password = password;
}

public boolean isValid() {
    return valid;
}

public void setValid(boolean valid) {
    this.valid = valid;
}

public void setFirstName(String firstName) {
    this.firstName = firstName;
}

public void setLastName(String lastName) {
    this.lastName = lastName;
}

public String getLastName() {
    return lastName;
}

public String getFirstName() {
    return firstName;
}

public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}
}
package com.intermediateDemo.home.controller;
import com.intermediateDemo.home.dao.ItemDao;
import com.intermediateDemo.home.dao.ItemDaoFactory;
import com.intermediateDemo.home.dto.ItemBean;
import com.intermediateDemo.login.dto.LoginBean;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;


public class DeleteExpense extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws NumberFormatException, ServletException, IOException {
ItemBean item = new ItemBean() ;


    try {
        ItemDao dao = ItemDaoFactory.getItemDao();
        HttpSession session = request.getSession(false);
        LoginBean user = (LoginBean) session.getAttribute("user");
        item.setId(Integer.parseInt(request.getParameter("id")));
        item.setEmail(user.getEmail());
        dao.deleteItem(item, user);
    } catch (Exception e) {
        e.printStackTrace();
    }
    finally {
        response.sendRedirect("homeservlet");
    }

}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    RequestDispatcher view;
    view = request.getRequestDispatcher("/home/home.jsp");
    view.forward(request,response);
}
}
 public void deleteItem(ItemBean item, LoginBean user) throws Exception {

   try {
        JdbcConnection connection =   new JdbcConnection();
        String query = "delete from testtable where id=? and email=?";
        Connection con = connection.getConnection();
        PreparedStatement pstm = con.prepareStatement(query);
        pstm.setInt(1, item.getId());
        pstm.setString(2, user.getEmail());
        System.out.println(pstm);
        pstm.executeUpdate();

    } catch (Exception e) {
        e.printStackTrace();
        throw e;
    }
}
<%--
Created by IntelliJ IDEA.
User: Dell
Date: 3/13/14
Time: 8:12 PM
To change this template use File | Settings | File Templates.
--%>
<%@ page import="com.intermediateDemo.home.dto.ItemBean" %>
<%@ page import="java.util.List" %>
<%@ page import="com.intermediateDemo.login.dto.LoginBean" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>

<title>home</title>
<link rel="stylesheet" type="text/css" href="style_css/mystylesheet.css">
<link rel=”stylesheet” href=”resource/css/bootstrap.css”  type=”text/css”/>
</head>
<body>
<jsp:include page="../includes/header.jsp"/>
<div id="content" style="margin-left: 330px;margin-bottom: 10px">
Welcome <%=session.getAttribute("email")%>

your id is  <%=session.getAttribute("userid")%>
your firstname is  <%=session.getAttribute("firstname")%>
<h2>Your Financial Management</h2>
    <form action="homeservlet" method="post">



        <!--start display-->
        <legend>

            <h2>Expense list</h2>

        </legend>
        <div>
            <table class="table table-bordered table-striped" style="padding-   left:200px;border:2px;border-bottom-color: limegreen">
                <thead>
                <tr style="background: limegreen">


                    <th >Expense title</th>
                    <th>Expense amount</th>
                    <th>Expense Date</th>
                </tr>
                </thead>
                <tbody>



                <c:forEach var="item"  items="${requestScope.itemList}" >
                    <tr style="background:#808080;color:#ffffff">

                        <td><c:out value="${item.getItemName()}"> </c:out></td>
                        <td><c:out value="${item.getItemPrice()}"> </c:out></td>
                        <td><c:out value="${item.getTransactionTime()}"> </c:out></td>
                        <td>
                        <form method="post" action="/deleteexpense">
                            <input type="hidden" name="id" value="${item.id}">
                            <input class="btn btn-mini btn-danger " type="submit" value="Delete"/>
                        <a class="btn btn-mini " href="edit?id=${item.id}">Edit</a>
                         </form>
                        </td>
                    </tr>
                </c:forEach>


                </tbody>
            </table>
        </div>            

    </form>
</div>

<jsp:include page="../includes/footer.jsp"/>
</body>
</html>

//DAO,在这里检索ItemBean的数据

    public List<ItemBean> getItemFromdb(LoginBean user) throws SQLException {
    List<ItemBean> itemList = new ArrayList<ItemBean>();
    JdbcConnection connecton = new JdbcConnection();
    //String query = "select * from testtable where userid = ?";
     String query = "select  * from testtable where  email = ?";
    ResultSet rs;
    try {
        Connection con = connecton.getConnection();
        PreparedStatement pstm = con.prepareStatement(query);
       // pstm.setInt(1, user.getUserid());
        pstm.setString(1,user.getEmail());
        rs = pstm.executeQuery();
        while (rs.next()) {
            ItemBean item = new ItemBean();
            item.setItemName(rs.getString("itemname"));
            item.setItemPrice(rs.getDouble("itemprice"));
            item.setTransactionTime(rs.getString("transactiontime"));
           // item.setUserid(rs.getInt("userid"));
            item.setEmail(rs.getString("email"));
            itemList.add(item); 


        }

        System.out.println("at jdbc code");
        for (ItemBean item1 : itemList) {
            System.out.println(item1.getItemName());
            System.out.println(item1.getItemPrice());
            System.out.println(item1.getTransactionTime());
        }
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return itemList;
}

//在一个页面中进行项目插入、检索和删除操作的JDBC代码是

package com.intermediateDemo.home.dao.mysql;
import com.intermediateDemo.common.JdbcConnection;
import com.intermediateDemo.home.dto.ItemBean;
import com.intermediateDemo.login.dto.LoginBean;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;


public class JdbcItemMysql {
public void itemtodb(ItemBean item, LoginBean user) throws Exception {
    JdbcConnection connection = new JdbcConnection();
    //String query = "insert into testtable    (itemname,itemprice,transactiontime,userid) values (?,?,?,?)";
   String query = "insert into testtable (itemname,itemprice,transactiontime,email) values (?,?,?,?)";
    try {
        Connection con = connection.getConnection();
        PreparedStatement pstm = con.prepareStatement(query);
        pstm.setString(1, item.getItemName());
        pstm.setDouble(2, Double.parseDouble(String.valueOf(item.getItemPrice())));
        pstm.setString(3, item.getTransactionTime());
        pstm.setString(4, user.getEmail());
       // pstm.setInt(4,user.getId());
        pstm.executeUpdate();
    } catch (Exception e) {
        e.printStackTrace();
        throw e;
    }
}

public List<ItemBean> getItemFromdb(LoginBean user) throws SQLException {
    List<ItemBean> itemList = new ArrayList<ItemBean>();
    JdbcConnection connecton = new JdbcConnection();
    //String query = "select * from testtable where userid = ?";
     String query = "select  * from testtable where  email = ?";
    ResultSet rs;
    try {
        Connection con = connecton.getConnection();
        PreparedStatement pstm = con.prepareStatement(query);
       // pstm.setInt(1, user.getUserid());
        pstm.setString(1,user.getEmail());
        rs = pstm.executeQuery();
        while (rs.next()) {
            ItemBean item = new ItemBean();
            item.setItemName(rs.getString("itemname"));
            item.setItemPrice(rs.getDouble("itemprice"));
            item.setTransactionTime(rs.getString("transactiontime"));
           // item.setUserid(rs.getInt("userid"));
            item.setEmail(rs.getString("email"));
            itemList.add(item); 


        }

        System.out.println("at jdbc code");
        for (ItemBean item1 : itemList) {
            System.out.println(item1.getItemName());
            System.out.println(item1.getItemPrice());
            System.out.println(item1.getTransactionTime());
        }
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return itemList;
}






public void deleteItem(ItemBean item, LoginBean user) throws Exception {

   try {
        JdbcConnection connection =   new JdbcConnection();
        String query = "delete from testtable where id=? and email=?";
        Connection con = connection.getConnection();
        PreparedStatement pstm = con.prepareStatement(query);
        pstm.setInt(1, item.getId());
        pstm.setString(2, user.getEmail());
        System.out.println(pstm);
        pstm.executeUpdate();

    } catch (Exception e) {
        e.printStackTrace();
        throw e;
    }
}

共有1个答案

许永年
2023-03-14

您没有将记录id从方法传递到jsp页面。您的getItemFromdb()应该是如下所示的

public List<ItemBean> getItemFromdb(LoginBean user) throws SQLException {

    //  whatever you are doing comes here
    while (rs.next()) {
        ItemBean item = new ItemBean();
        item.setId(rs.getInt("id");  //  you need to have this, here id is the the primary key of the table
        item.setItemName(rs.getString("itemname"));
        item.setItemPrice(rs.getDouble("itemprice"));
        item.setTransactionTime(rs.getString("transactiontime"));
     // item.setUserid(rs.getInt("userid"));
        item.setEmail(rs.getString("email"));
        itemList.add(item); 
    }

    //  rest of the code
}

以便在jsp页面中使用该id来标识记录,执行您想要执行任何操作

 类似资料:
  • 问题内容: 从视图中删除一行,是否会从创建该视图的基表中删除相应的行?我正在使用MySQL。 问题答案: 是的,它会的。唯一需要注意的是权限。 引用官方文档 有些观点是可更新的。也就是说,您可以在诸如UPDATE,DELETE或INSERT之类的语句中使用它们来更新基础表的内容。为了使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。还有某些其他构造会使视图不可更新。

  • 本文向大家介绍从视图中删除行会从MySQL的基表中删除行吗?,包括了从视图中删除行会从MySQL的基表中删除行吗?的使用技巧和注意事项,需要的朋友参考一下 是的,从视图中删除行从基表中删除行。让我们通过创建一个新表来了解这一点。创建表的查询如下 使用insert命令在表中插入一些记录。查询如下- 使用select语句显示表中的所有记录。查询如下- 以下是输出 让我们创建一个视图。创建视图的查询如下

  • 我一直试图通过java代码从DynamoDB中的表中删除一项,但每次尝试都会导致相同的错误: com.amazonaws.AmazonServiceException:提供的键元素与架构不匹配(服务:AmazonDynamoDBv2;状态代码:400;错误代码:ValidationException; 我当前的尝试非常简单,如下所示: tablename只是表名,凭证已被验证为正确,cognito

  • 问题内容: 我正在尝试使用SQL从连接在一起的多个表中删除多行。 表A连接到表B表B连接到表C 我想删除表B和C中与表A中的一行相对应的所有行 问题答案: 好吧,如果您使用过InnoDB表,则可以使用外键设置级联删除,这将自动完成所有操作。但是,如果您出于某种原因使用MyISAM,则只需使用多表DELETE即可:

  • 当然,这些列表有setter和getter。现在我想实现以用户身份不参加这些事件的可能性。因此,我尝试了以下方法: 我得到的例外情况如下: 尽管我使用了一些方法来确保执行惰性提取:

  • 我设法创建了一个自定义列表视图,并为每一行添加了一个删除按钮。删除按钮运行良好,当我单击按钮时,该行会从数据库中删除。问题是,当我删除一行时,它会保留在列表中,直到我通过移动到另一个片段来刷新片段并返回,然后它从列表中消失。我想要的是,当我删除一行时,它会立即从列表视图中消失。我尝试了一些解决方案来刷新整个片段或删除完成后的列表视图,但它们不起作用! 这是我为适配器类中的删除按钮编写的代码 之后