将mySQL MAX值设置为java变量

时间:2017-11-15 23:47:51

标签: java mysql database max

嘿伙计们我试图从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;
}

1 个答案:

答案 0 :(得分:2)

使用声明,理想情况下是准备好的声明:

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代码中不可用。要访问它,您需要再次编写另一个查询。