【发布时间】: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