大家好,我试图从mySQL MAX函数获取值(试图获得最高的客户ID)并将其存储在Java代码的变量中。似乎无法使事情正常进行。
public static int findMaxID() {
int maxID = 0;
String updateStmt =
"SELECT @maxID := MAX(idCustomer)\n" +
"FROM customers\n";
try {
DBUtil.dbExecuteQuery(updateStmt);
System.out.println(maxID);
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return maxID;
}
最佳答案
使用一条语句,最好是一条准备好的语句:
int maxID = 0;
String sql = "SELECT MAX(idCustomer) AS max_id FROM customers";
PreparedStatement ps = conn.prepareStatement(sql);
ResultSet rs = ps.executeQuery();
if (rs.next()) {
int maxID = rs.getInt("max_id"); // access the max value via its alias
}
尽管当前查询可能是有效的MySQL,但会话变量
@maxID
仅在MySQL上可用,而在Java代码中不可用。要访问它,您将需要再次编写另一个查询。关于java - 将mySQL MAX值设置为java变量,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/47319252/