将MySQL最大值设置为java变量 [英] Set mySQL MAX value to java variable

查看:49
本文介绍了将MySQL最大值设置为java变量的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

嘿,伙计们,我正在尝试从MySQL Max函数中获取值(尝试获取最高的客户ID),并将其存储在Java代码中的一个变量中。似乎无法使这东西工作。

public static int findMaxID() {
    int maxID = 0;
    String updateStmt =
            "SELECT @maxID := MAX(idCustomer)
" +
                    "FROM customers
";
    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代码中不可用。若要访问它,您需要再次编写另一个查询。

这篇关于将MySQL最大值设置为java变量的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆