【问题标题】:Java SQLite : exploiting a ResultSet for a COUNT queryJava SQLite:利用 ResultSet 进行 COUNT 查询
【发布时间】:2015-12-16 00:06:46
【问题描述】:

我在 Java 应用程序中使用 SQLite,在添加行之前,我需要知道是否可能违反 UNIQUE 约束。

因此,我编写了一个小方法来计算具有相同唯一值的行数(这里是一个用于我的表 User 的方法,在创建数据库的类中;我经常添加用户):

public boolean testUserId(String a) {
    try {
        String query = "SELECT COUNT(*) FROM USER WHERE ID = " + a + ")";

        ResultSet rs = select(query);

        if (rs.next()) {
            System.out.println("Point 1");
            boolean ok = (rs.getInt(1) == 0);

            if (ok) {
                return true;
            }
        }

    } catch (Exception e) {
        System.err.println(e.getClass().getName() + ": " + e.getMessage());
        System.exit(0);
    }
    return false;
}

但它永远不会转到Point 1。任何熟悉这个的人可以告诉我我错在哪里吗?提前致谢。

【问题讨论】:

  • 为什么你需要事先知道?为什么不尝试插入和处理可能发生的异常呢?否则,您需要重复数据库已有的相同验证逻辑。
  • 如果没有到第1点,你很可能有异常。

标签: java sql sqlite unique-constraint


【解决方案1】:

尝试引用值

String query = "SELECT COUNT(*) FROM USER WHERE ID = '" + a + "')";

【讨论】:

    猜你喜欢
    • 2011-11-25
    • 1970-01-01
    • 2019-10-23
    • 2017-02-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多