Connection con= DriverManager.getConnection("jdbc:mysql://"+ host, user, pass);
Statement state = con.createStatement();
con.setAutoCommit(false);
state.executeUpdate("INSERT IGNORE `kb_manage`.`serial` (`serial`) VALUES ('10001')");
state.executeUpdate("INSERT `kb_manage`.`serial` (`serial`) VALUES ('10001') ON
DUPLICATE KEY UPDATE `serial`='10002'");
con.commit();
这是我在我的某个应用程序中使用的代码的简化版本。应用程序本身是用java编写的,并连接到MySQL数据库。我正在尝试创建一个具有多个插入查询的事务,这些查询使用IGNORE和ON DUPLICATE KEY UPDATE。此示例中的表包含1个名为serial的列,它被设置为PRIMARY KEY。我遇到的问题是我得到了:
java.sql.SQLException: DUP_PK_KEY
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3609)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3541)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2002)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2163)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2618)
at com.mysql.jdbc.ConnectionImpl.commit(ConnectionImpl.java:1654)
at remote.SerialValue.main(SerialValue.java:19)
起初我以为我做错了SQL,直到完全删除了事务并且一切正常......这不是一个非常有问题的事务。什么出错了?司机是否只是忽略了IGNORE和ON DUPLICATE KEY,还是我做了一件非常错误的事情?感谢您的帮助。
答案 0 :(得分:1)
更改autoCommit状态后创建语句:
con.setAutoCommit(false);
Statement state = con.createStatement();