java语句到这里异常:ResultSet rs = ps.executeQuery();

public ArrayList<User> yaoyiyao (User u) {
ArrayList<User> StrangerList= new ArrayList<User>();
Connection con = DButil.connect();
String sql1 = "UPDATE `user` SET `user`._longitude =?,`user`._latitude = ? where `user`._id=?";
try {
System.out.println("这里是摇一摇内部try!");
PreparedStatement ps = con.prepareStatement(sql1);
ps.setDouble(1, u.getLongitude());
ps.setDouble(2, u.getLatitude());
ps.setInt(3, u.getId());
ps.executeUpdate();
System.out.println("这里执行完摇一摇用户的经纬度的数据库的更新!已经执行了executeUpdate命令!");
ResultSet rs = ps.executeQuery();//executeQuery()方法会把数据库响应的查询结果存放在ResultSet类对象中供我们使用。
System.out.println("这里执行完ResultSet rs = ps.executeQuery();语句!");
while(rs.next()){ //next()函数:通过next来索引,判断是否有下一个记录。一开始就指向内存的首地址,即第一条记录,如果返回值为true,指针会自动指向下一条记录。
Double longitute = rs.getDouble(8);
Double latitude = rs.getDouble(9);
Double longitute1=u.getLongitude();
Double latitude1 = u.getLatitude();
Double distance = GetDistance(latitude, longitute, latitude1, longitute1);
if(distance<=1000){
StrangerList.add((User) rs);
}
}
rs.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
DButil.close(con);
}
return StrangerList;
}
异常信息:
java.sql.SQLException: Can not issue data manipulation statements with executeQuery().
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.Statement.checkForDml(Statement.java:417)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1383)
at com.way.chat.dao.impl.UserDaoImpl.yaoyiyao(UserDaoImpl.java:126)
at com.way.chat.server.InputThread.readMessage(InputThread.java:99)
at com.way.chat.server.InputThread.run(InputThr...

你自己注释的很明白了 //executeQuery()方法会把数据库响应的查询结果存放在ResultSet
这是查询方法,是用来查询的,数据库会吧查询的结果集放在这个ResultSet里面
修改用executeUpdate这个方法追问

executeUpdate我在executeQuery()前用过了,用来更新了下数据库,现在想用executeQuery()来查询的呀,executeUpdate只能返回更新记录数啊,我要用到rs.getDouble方法

追答

在你的查询语句前重新获取这个PreparedStatement对象,然后执行查询
简单点说就是
String sql2 = "select * from xxx"
PreparedStatement ps2 = con.prepareStatement(sql2);
有参数写参数没参数调用ps2.executeQuery()

追问

谢谢1

温馨提示:内容为网友见解,仅供参考
第1个回答  2015-05-21
update 语句不能使用executeQuery()方法来执行..
第2个回答  2015-05-21
将executeQuery()方法改成execute()。
相似回答