我正在用 Java 创建一个客户端-服务器应用程序。在服务器上我有一个 Microsoft Access 数据库 (SQL),在客户端我有 JFrame 表单。我在客户端和服务器之间进行了通信,并且没有问题。我的表单有一个特定的文本字段(我们称之为txtField)。我需要通过表单将某些数据插入到我的数据库中。但在此之前,需要检查 txtField 中输入的值是否已经存在于数据库中。我该怎么做,以及在哪里编写这段代码,我猜是表格?谢谢
问问题
6529 次
3 回答
3
我需要通过表单将某些数据插入到我的数据库中。但在此之前,需要检查 txtField 中输入的值是否已经存在于数据库中。
不可以。如果它不存在,您需要将其插入到数据库中。正确的方法是尝试插入并捕获失败。否则,您正在检查和插入之间创建时间窗口问题,在此期间另一个客户端可以进行插入。
于 2013-06-22T08:28:52.390 回答
1
你应该这样写你的查询:
Insert into [Table](Field1,Field2)
Select Top 1 Val1,Val2
FROM
[Table]
WHERE NOT EXISTS(SELECT * FROM [Table] Where Field1 = Val1 and Field2 = Val2)
在这里你可以看到示例: 基于目标表中数据的条件插入查询
于 2013-06-22T10:59:58.470 回答
0
以下是我在 Java 中使用参数化查询的方法:
import java.sql.*;
public class JDBCQuery {
public static void main(String args[]) {
Connection conn = null;
PreparedStatement s = null;
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection(
"jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};" +
"DBQ=C:\\Users\\Public\\Database1.accdb;");
String txtField = "Java"; // value to insert
s = conn.prepareStatement(
"INSERT INTO Table1 (thing) " +
"SELECT ? AS thing " +
"FROM (SELECT COUNT(*) FROM Table1) " +
"WHERE NOT EXISTS " +
"( " +
"SELECT thing FROM Table1 " +
"WHERE thing=? " +
")");
s.setString(1, txtField);
s.setString(2, txtField);
if (s.executeUpdate() > 0) {
System.out.println("The row was inserted.");
}
else {
System.out.println("The row was not inserted.");
}
} catch( Exception e ) {
e.printStackTrace();
} finally {
try {
if (s != null) {
s.close();
}
if (conn != null) {
conn.close();
}
} catch( Exception e ) {
e.printStackTrace();
}
}
}
}
于 2013-06-22T12:45:44.080 回答