[英]Query does not return output
I'm writing a program where when user selects a certain choice using radio buttons, then parameters and sql statements get assigned: 我正在编写一个程序,当用户使用单选按钮选择某个选项时,将分配参数和sql语句:
if(r1.isSelected())//SNo
{
cmd="SELECT * FROM CALLDETAILS WHERE SNo=?";
parameter=tf1.getText();
}
else if(r2.isSelected())//Month-wise
{
cmd="SELECT SNO, DATE, COMPANY,STATUS FROM CALLDETAILS WHERE MONTH(DATE)=?";
parameter=tf1.getText();
}
else if(r2.isSelected())//Username
{
cmd="SELECT * FROM CALLDETAILS WHERE ATTENDED_BY=?";
parameter=tf1.getText();
}
else if(r3.isSelected())//Company
{
cmd="SELECT * FROM CALLDETAILS WHERE COMPANY=?";
parameter=tf1.getText();
}
else//Status
{
cmd="SELECT * FROM CALLDETAILS WHERE Status=?";//Resolved. in process, pending
parameter=tf1.getText();
}
When I run this: 当我运行这个:
try
{
Connection con=DriverManager.getConnection("jdbc:mysql://localhost/tenderdetails?user=root&password=");
PreparedStatement ps;
ps=con.prepareCall(cmd);
ps.setString(1,parameter);
ResultSet rs=ps.executeQuery();
while(rs.next())
{
int sno=rs.getInt(1);
Timestamp dt=rs.getTimestamp(2);
System.out.println(sno+ " "+dt);//HERE!
}
con.close();
System.out.println("here too");
}
catch(SQLException se)
{
JOptionPane.showMessageDialog(this, "Error: "+se.getMessage());
}
There is no output of the statement marked HERE. 没有标记为HERE的语句的输出。 Why is that? 这是为什么?
It would seem that your statements aren't necessarily set to what you think; 看来您的陈述不一定符合您的想法。
else if(r2.isSelected())//Month-wise // <-- r2
{
cmd="SELECT SNO, DATE, COMPANY,STATUS FROM CALLDETAILS WHERE MONTH(DATE)=?";
parameter=tf1.getText();
}
else if(r2.isSelected())//Username // <-- r2 again...? Won't ever be hit.
Also, although most likely not your problem, getInt(1)
and getTimestamp(2)
seem a bit dangerous with SELECT *
. 另外,尽管很可能不是您的问题,但使用SELECT *
, getInt(1)
和getTimestamp(2)
似乎有些危险。
check the getConnection()
string and your Query/Prepared statement. 检查getConnection()
字符串和您的Query / Prepared语句。
Since it doesn't return any results the problem is likely here. 由于它不返回任何结果,因此这里可能出现问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.