例子4:条件查询数据库中表的数据(JSP)

index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'index.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
  </head>
  
  <body>
  <form action="byNumber.jsp" Method="post">
   <br>根据产品号查询
   <br/>输入产品号:<input type=text name="number">
   <br/><br>
   <input type=submit name="g" value="提交">
   </form>
   <form action="byPrice.jsp" Method="post">
   <br/><br>
   根据价格查询
   <br></br>价格在<input type=text name="priceMin" size=8>
   至<input type=text name="priceMax"size=8>之间
   <input type=submit value="提交">
   </form>
  </body>
</html>

byNumber.jsp

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@ taglib tagdir="/WEB-INF/tags" prefix="com"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'byNumber.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
   <% String number=request.getParameter("number");
   if(number==null)
      number ="";
   byte [] bb =number.getBytes("iso-8859-1");
   number=new String(bb);
%>
 <com:NumberCondition number="<%=number%>" /> 
 根据产品号<%=number%>查询到的记录:
<BR><%=queryResultByNumber%>
  </body>
</html>

byPrice,jsp

<%@ page contentType="text/html;charset=GB2312" %>
<%@ taglib tagdir="/WEB-INF/tags" prefix="inquire"%>
<HTML><BODY><Font size=2>
<% String min=request.getParameter("priceMin");
   String max=request.getParameter("priceMax");
%>
 <inquire:PriceCondition  priceMin="<%=min %>" priceMax="<%=max%>" />
 价格在<%=min%>至 <%=max%>之间的记录:
 <BR><%=queryResultByPrice%>  <%--queryResultByPrice是Tag文件返回的对象--%>
</Font></BODY></HTML>

NumberCondition.tag

<%@ tag pageEncoding="GB2312" %>
<%@ tag import="java.sql.*" %>
<%@ attribute name="number" required="true" %>
<%@ variable name-given="queryResultByNumber" scope="AT_END" %>
<%  StringBuffer result;
    result=new StringBuffer();
    try{   Class.forName("com.mysql.jdbc.Driver");
    }
    catch(Exception e){} 
    Connection con;
    Statement sql; 
    ResultSet rs;
    int n=0;
    try{  result.append("<table border=1>"); 
          String uri=
          "jdbc:mysql://127.0.0.1/warehouse?"+
          "user=root&password=&characterEncoding=gb2312";
          con=DriverManager.getConnection(uri);
          DatabaseMetaData metadata=con.getMetaData();
          ResultSet rs1=metadata.getColumns(null,null,"product",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();
          String condition=
          "SELECT * FROM product Where number ='"+number+"'";
          rs=sql.executeQuery(condition);
          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(e);
    }
    jspContext.setAttribute("queryResultByNumber",new String(result)); 
%> 

PriceCondition.tag

<%@ tag pageEncoding="GB2312" %>
<%@ tag import="java.sql.*" %>
<%@ attribute name="priceMax" required="true" %>
<%@ attribute name="priceMin" required="true" %>
<%@ variable name-given="queryResultByPrice" scope="AT_END" %>
<%  float max=Float.parseFloat(priceMax);
    float min=Float.parseFloat(priceMin);
    StringBuffer result;
    result=new StringBuffer();
    try{   Class.forName("com.mysql.jdbc.Drive");
    }
    catch(Exception e){} 
    Connection con;
    Statement sql; 
    ResultSet rs;
    int n=0;
    try{  result.append("<table border=1>"); 
          String uri="jdbc:mysql://127.0.0.1/warehouse";
          con=DriverManager.getConnection(uri,"root","");
          DatabaseMetaData metadata=con.getMetaData();
          ResultSet rs1=metadata.getColumns(null,null,"product",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();
          String condition=
         "SELECT * FROM product Where price <="+
          max+" AND "+"price >= "+min;
          rs=sql.executeQuery(condition);
          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(e);
    }
    jspContext.setAttribute("queryResultByPrice",new String(result)); 
%>

文件目录结构显示:

运行效果显示图:

 

 

 

 

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,这里提供一个简单的 Java Servlet 代码示例,可以连接到数据库,查询表中的数据并将其显示到网页上。在这个示例中,我们使用了 MySQL 数据库和 JSP 技术。 首先,我们需要创建一个 JDBC 工具类,用于连接到数据库并执行操作。这里我们使用了 PreparedStatement 对象,可以防止 SQL 注入攻击。 ```java import java.sql.*; public class JdbcUtil { private static final String URL = "jdbc:mysql://localhost:3306/mydatabase?useUnicode=true&characterEncoding=utf8"; private static final String USER = "root"; private static final String PASSWORD = "password"; public static Connection getConnection() throws SQLException { return DriverManager.getConnection(URL, USER, PASSWORD); } public static void close(Connection conn, Statement stmt, ResultSet rs) { try { if (rs != null) rs.close(); } catch (SQLException e) { e.printStackTrace(); } try { if (stmt != null) stmt.close(); } catch (SQLException e) { e.printStackTrace(); } try { if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } public static PreparedStatement prepareStatement(Connection conn, String sql, Object... params) throws SQLException { PreparedStatement pstmt = conn.prepareStatement(sql); for (int i = 0; i < params.length; i++) { pstmt.setObject(i + 1, params[i]); } return pstmt; } } ``` 然后,我们编写一个 Servlet,用于处理 HTTP 请求并显示数据。在 `doGet()` 方法中,我们连接到数据库,查询表中的数据,将其转换为 HTML 表格的形式并输出到响应中。 ```java import java.io.IOException; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class MyServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { try { // 连接到 MySQL 数据库 Connection conn = JdbcUtil.getConnection(); // 创建 PreparedStatement 对象 PreparedStatement pstmt = JdbcUtil.prepareStatement(conn, "SELECT * FROM mytable"); // 执行查询语句 ResultSet rs = pstmt.executeQuery(); // 将查询结果转换为 HTML 表格 StringBuilder sb = new StringBuilder(); sb.append("<html><head><title>My Page</title></head><body><table border='1'><tr><th>id</th><th>name</th><th>age</th></tr>"); while (rs.next()) { sb.append("<tr><td>").append(rs.getInt("id")).append("</td><td>").append(rs.getString("name")).append("</td><td>").append(rs.getInt("age")).append("</td></tr>"); } sb.append("</table></body></html>"); // 将结果输出到响应中 response.setContentType("text/html;charset=utf-8"); response.getWriter().write(sb.toString()); // 关闭连接 JdbcUtil.close(conn, pstmt, rs); } catch (SQLException ex) { ex.printStackTrace(); } } } ``` 最后,我们需要创建一个 JSP 页面,用于向用户展示数据。在这个页面中,我们可以使用 `<jsp:include>` 标签来引入 Servlet 的输出结果。例如: ```html <html> <head> <title>My Page</title> </head> <body> <h1>My Page</h1> <jsp:include page="/myservlet"/> </body> </html> ``` 在这个例子中,`/myservlet` 是我们创建的 Servlet 的 URL 映射。当用户请求这个 URL 时,Servlet查询数据库并将结果输出到响应中,然后 JSP 页面将其包含在页面中进行展示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值