JSP 常用于開發(fā)網(wǎng)站,其中條件查詢是非常常用的功能。MySQL 是一種流行的開源數(shù)據(jù)庫,也是很多網(wǎng)站經(jīng)常使用的數(shù)據(jù)庫之一。下面是一個 JSP 頁面中通過條件查詢 MySQL 數(shù)據(jù)庫的示例:
<%@ page import="java.sql.*" %>
<%!
String url = "[數(shù)據(jù)庫的 URL 去掉尖括號和括號里的信息]";
String user = "[用戶名去掉尖括號和括號里的信息]";
String password = "[密碼去掉尖括號和括號里的信息]";
Connection conn = null;
Statement stmt = null;
public void connect() throws SQLException {
conn = DriverManager.getConnection(url, user, password);
stmt = conn.createStatement();
}
public void close() throws SQLException {
stmt.close();
conn.close();
}
%>
<%!
String query = "SELECT * FROM [表名去掉尖括號和括號里的信息] WHERE [條件]";
%>
<%!
ResultSet rs = null;
public void executeQuery() throws SQLException {
rs = stmt.executeQuery(query);
}
public void closeRs() throws SQLException {
rs.close();
}
%>
<%!
String display() throws SQLException {
executeQuery();
StringBuffer sb = new StringBuffer();
sb.append("<table>\n");
while (rs.next()) {
sb.append("<tr>\n");
sb.append("<td>" + rs.getString(1) + "</td>\n"); // 將結(jié)果集中的數(shù)據(jù)顯示在表格中
sb.append("<td>" + rs.getString(2) + "</td>\n");
// ...
sb.append("</tr>\n");
}
sb.append("</table>\n");
closeRs();
return sb.toString();
}
%>
<%@ page language="java" %>
<html>
<head>
<title>條件查詢</title>
</head>
<body>
<%@ page contentType="text/html;charset=UTF-8" %>
<form method="post" action="#">
<p>輸入條件:<input type="text" name="condition" /></p>
<p><input type="submit" value="查詢" /></p>
</form>
<%
if (request.getMethod().equals("POST")) {
String condition = request.getParameter("condition");
query = "SELECT * FROM [表名去掉尖括號和括號里的信息] WHERE " + condition;
try {
connect();
out.println(display());
close();
} catch (SQLException e) {
out.println(e.getMessage());
}
}
%>
</body>
</html>
上述代碼中使用了多個 JSP 內(nèi)置對象,例如 request、response、out 等,同時也 import 了 java.sql 包中的一些類。其中,connect() 方法用于連接數(shù)據(jù)庫,executeQuery() 方法用于執(zhí)行查詢語句,display() 方法用于將結(jié)果集中的數(shù)據(jù)顯示在表格中。