我正在使用一个在 Apache Tomcat 上运行并以 Mysql 数据库作为后端的 Web 应用程序
我想使用 Where 子句检索特定列的多行
例如,如果我给 select * from xyz where type=abc
我应该得到所有类型为 abc 的行。
问题:
我使用 JDBC 连接来实现这一点,但是只返回与 where 条件匹配的第一行而不是所有行(即使多行匹配数据库中的条件)
请帮我解决这个问题
代码:
<%@ page import="java.sql.*" %>
<html>
<head><link href="style.css" rel ="stylesheet" type="text/css"></head>
<body bgcolor="white" >
<div id="container">
<div id="header">
<img src="logo.jpg">
<div class ="horiztext"><p> Order Tracker</p></div>
</div>
</div>
<br>
<img src="banner.jpg" width="1500 " height="5"><br>
<% if(session.getAttribute("username") !=null)
{
%>
<div id="navbar">
<ul>
<li><a href="newoder.jsp">New Order</a></li>
<li><a href="updateorder.jsp">Update Order</a></li>
<li><a href="trackorder.jsp">Track Order</a></li>
<li><a href="trackdelay.jsp">Track Delay</a></li>
<li><a href="vieworder.jsp">View Database</a></li>
<li><a href="delete.jsp">Delete Order</a></li>
<li><a href="logout.jsp">Logout</a></li>
</ul>
</div>
<br>
<br>
<form>
<TABLE cellpadding="15" border="1" style="background-color: #ffffcc;">
<%
String ProductNamez=request.getParameter("ProductName");
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3307
/test","root", "root");
Statement st=conn.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM inventory WHERE ProductName = '"+
ProductNamez +"' ");
if(rs.next()){
%>
<tr>
<tr><th>Serial No</th>
<th>Product Name</th>
<th>Product Type</th>
<th>Model</th>
<th>Make</th>
<th>License / Voucher</th>
<th>Location</th>
</tr>
<tr>
<td><%=rs.getString(1)%></td>
<td><%=rs.getString(2)%></td>
<td><%=rs.getString(3)%></td>
<td><%=rs.getString(4)%></td>
<td><%=rs.getString(5)%></td>
<td><%=rs.getString(6)%></td>
<td><%=rs.getString(7)%></td>
</tr>
<%
}
%>
</table>
</form>
<%
}
else { %>
you are not logged in click here to <a href="eric.jsp"><b>login</b></a>
<%
} %>
</body>
</html>