java MySQL事务/ INSERT IGNORE和ON DUPLICATE KEY UPDATE

时间:2012-09-06 14:51:47

标签: java mysql sql transactions insert

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,还是我做了一件非常错误的事情?感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

更改autoCommit状态后创建语句:

con.setAutoCommit(false);
Statement state = con.createStatement();