例子7:更新记录——更新数据库中表的数据(JSP)

产品更新操作示例
本文展示了一个使用JSP和MySQL进行产品信息更新的示例,包括前端表单收集、后台数据处理及数据库更新过程。

一、文件目录结构图示

二、运行效果显示

 

 

三、代码示例

index.jsp

<%@ page contentType="text/html;charset=GB2312" %>
<%@ taglib tagdir="/WEB-INF/tags" prefix="inquire"%>
<HTML><BODY ><FONT size=2>
<FORM action="newResult.jsp" method=post>
<table border=1>
<tr><td> 输入要更新的产品的产品号:</td>
<td><Input type="text" name="number"></td></tr>
<tr><td>输入新的名称:</td><td><Input type="text" name="name"></td></tr>
<tr><td>输入新的生产日期:</td><td><Input type="text" name="madeTime"></td></tr>
<tr><td>输入新的价格:</td><td><Input type="text" name="price"></td></tr>
</table>
<BR><Input type="submit" name="b" value="提交更新">
<BR>product表更新前的数据记录是:
<inquire:QueryTag  dataBaseName="warehouse"
                   tableName="product" 
                   user="root" password=""/> 
<BR> <%=queryResult %>
</Font></BODY></HTML>

newResult.jsp

<%@ page contentType="text/html;charset=GB2312" %>
<%@ taglib tagdir="/WEB-INF/tags" prefix="renew"%>
<%@ taglib tagdir="/WEB-INF/tags" prefix="inquire"%>
<HTML><BODY bgcolor=pink><Font size=2>
<% String nu=request.getParameter("number");
   String na=request.getParameter("name");
   String mT=request.getParameter("madeTime");
   String pr=request.getParameter("price");
   byte bb[]=na.getBytes("iso-8859-1");
   na=new String(bb);
%>
 <renew:NewRecord number="<%=nu%>"name="<%=na%>"madeTime="<%=mT%>"price="<%=pr%>"/> 
 <BR>product表更新后的数据记录是:
 <inquire:QueryTag  dataBaseName="warehouse"tableName="product"user="root"password=""/> 
<BR> <%= queryResult%>
</Font>
</BODY>
</HTML> 

QueryTag.tag

<%@ tag pageEncoding="GB2312" %>
<%@ tag import="java.sql.*" %>
<%@ attribute name="dataBaseName" required="true" %>
<%@ attribute name="tableName" required="true" %> 
<%@ attribute name="user" required="true" %>  
<%@ attribute name="password" required="false" %>  
<%@ variable name-given="biao" scope="AT_END" %>
<%@ variable name-given="queryResult" scope="AT_END" %>
<%  StringBuffer result;     
    result=new StringBuffer();
    try{  Class.forName("com.mysql.jdbc.Driver");
    }
    catch(Exception e){} 
    Connection con;
    Statement sql; 
    ResultSet rs;
    try{  result.append("<table border=1>"); 
          String uri="jdbc:mysql://127.0.0.1/"+dataBaseName;
          con=DriverManager.getConnection(uri,user,password);
          DatabaseMetaData metadata=con.getMetaData();
          ResultSet rs1=metadata.getColumns(null,null,tableName,null);
          int 字段个数=0;
          result.append("<tr>");
          while(rs1.next()){
             字段个数++;
             String clumnName=rs1.getString(4);
             result.append("<td>"+clumnName+"</td>");
          }
          result.append("</tr>");
          sql=con.createStatement();
          rs=sql.executeQuery("SELECT * FROM "+tableName);
          while(rs.next()){
               result.append("<tr>");
               for(int k=1;k<=字段个数;k++) 
                  result.append("<td>"+rs.getString(k)+"</td>");
               result.append("</tr>");
          }
          result.append("</table>");
          con.close();
    }
    catch(SQLException e){
          result.append("请输入正确的用户名和密码");
}
//返回对象queryResult: 
    jspContext.setAttribute("queryResult",new String(result)); 
    jspContext.setAttribute("biao",tableName);          //返回biao对象
%> 

newRecord.tag

<%@ tag pageEncoding="GB2312" %>
<%@ tag import="java.sql.*" %>
<%@ attribute name="number" required="true" %>
<%@ attribute name="name" required="true" %>
<%@ attribute name="madeTime" required="true" %>
<%@ attribute name="price" required="true" %>
<%  float p=Float.parseFloat(price);
    String condition1="UPDATE product SET name= '"+name+
                   "' WHERE number="+"'"+number+"'" ,
           condition2="UPDATE product SET madeTime= '"+madeTime+
                   "' WHERE number="+"'"+number+"'",
           condition3="UPDATE product SET price= "+price+
                      " WHERE number="+"'"+number+"'" ;
    try{   Class.forName("com.mysql.jdbc.Driver");
    }
    catch(Exception e){} 
    Connection con;
    Statement sql; 
    ResultSet rs;
   try{  String uri=
        "jdbc:mysql://127.0.0.1/warehouse?"+
         "user=root&password=&characterEncoding=gbk";
         con=DriverManager.getConnection(uri);
         sql=con.createStatement();
         sql.executeUpdate(condition1);
         sql.executeUpdate(condition2);
         sql.executeUpdate(condition3);
         con.close();
   }
   catch(Exception e){
         out.print(""+e);
   }
%>
### 如何在 IntelliJ IDEA 中用 JSP 实现从数据库查询并展示数据 #### 准备工作 为了使JSP页面能够成功连接到MySQL数据库,在IntelliJ IDEA环境中需先配置好Java开发环境以及安装必要的库文件。确保已下载并配置了JDK,并且IDEA识别到了该JDK设置[^1]。 #### 添加依赖项 对于JDBC驱动程序来说,应当将其加入项目的类路径下以便于编译器可以找到所需的类定义。可以通过Maven或Gradle管理这些外部资源;如果采用手动方式,则要将`mysql-connector-java-x.x.xx.jar`放置于WEB-INF/lib目录内[^2]。 #### 配置Web应用结构 创建一个新的动态Web模块时,选择合适的Servlet API版本支持JSP技术。接着按照标准布局构建应用程序框架——src/main/java用于源代码, src/main/webapp存放网页文件(.jsp), web.xml作为部署描述符位于WEB-INF之下[^3]。 #### 编写JSP页面与Java Bean/DAO层交互逻辑 下面是一个简单的例子说明怎样利用JSTL标签库简化操作流程: ```html+jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head><title>Book List</title></head> <body> <h2>List of Books:</h2> <table border="1"> <tr> <th>ID</th> <th>Title</th> <th>Author</th> </tr> <c:forEach var="book" items="${books}"> <tr> <td>${book.id}</td> <td>${book.title}</td> <td>${book.author}</td> </tr> </c:forEach> </table> </body> </html> ``` 上述代码片段展示了如何遍历名为`${books}`的对象列表并将每一本书的信息呈现给用户查看。这里假设已经存在一个返回书籍集合的方法被调用了。 #### 数据访问对象(DAO) 编写专门处理持久化存储相关事务的类,比如建立SQL语句执行增删改查等功能。注意不同版本之间可能存在差异,特别是针对MySQL 8.0以上版本时要注意URL参数的变化。 ```java public class BookDao { private static final String URL = "jdbc:mysql://localhost:3306/testdb?useSSL=false&serverTimezone=UTC"; private static final String USER = "root"; private static final String PASSWORD = ""; public Connection getConnection() throws SQLException { return DriverManager.getConnection(URL, USER, PASSWORD); } public List<Book> getAllBooks(){ try (Connection conn = getConnection()){ Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM books"); ArrayList<Book> list = new ArrayList<>(); while(rs.next()){ int id = rs.getInt("id"); String title = rs.getString("title"); String author = rs.getString("author"); list.add(new Book(id,title,author)); } return list; } catch (SQLException e){ throw new RuntimeException(e.getMessage()); } } } ``` 这段示例中的`getAllBooks()`函数负责获取所有记录并通过迭代构造出实体bean实例组成的数组供前端渲染使用。 #### Servlet控制器 最后一步就是把业务逻辑串联起来形成完整的请求响应链路。当客户端发起HTTP GET请求至特定URI模式匹配路由规则之后触发对应处理器动作完成实际的数据检索任务再转发视图组件进行最终展现。 ```java @WebServlet("/list-books") public class BookListServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 创建 DAO 对象 BookDao dao = new BookDao(); // 调用方法取得数据集 List<Book> bookList = dao.getAllBooks(); // 将结果存入 request 属性中 req.setAttribute("books", bookList); // 请求分派转向目标 jsp 页面 RequestDispatcher dispatcher = getServletContext().getRequestDispatcher("/index.jsp"); dispatcher.forward(req,resp); } } ``` 通过这种方式实现了服务器端接收到来自浏览器发出的动作指令后依据预设好的算法计算得出所需信息反馈回去的过程。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值