【发布时间】:2017-01-31 01:26:20
【问题描述】:
我有下表 cl:
id - int(10) primary key
contact - int(10)
list - int(10)
在联系人和列表上具有唯一索引。当我按 100 条记录同时运行以下查询时:
INSERT INTO cl(list, contact) VALUES (?, ?) ON DUPLICATE KEY UPDATE cl.id = cl.id
在高压下它会失败大约 20% 并出现以下错误:
java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'ON DUPLICATE KEY UPDATE cl.id = cl.id' at line 1
80% 的查询运行良好。当我使用相同的参数重新运行失败的查询时,再次失败 20%。
为什么有些查询失败,然后第二次执行时没有产生错误?
【问题讨论】:
-
我认为您的 sql 没有意义(不是以粗鲁的方式)....我认为您应该执行以下操作,例如,如果您想更新列表,则:
INSERT INTO cl(list, contact) VALUES (?, ?) ON DUPLICATE KEY UPDATE list = ?...或者如果你想更新联系人,那么你应该尝试:INSERT INTO cl(list, contact) VALUES (?, ?) ON DUPLICATE KEY UPDATE contact = ?...或者如果你想同时更新:INSERT INTO cl(list, contact) VALUES (?, ?) ON DUPLICATE KEY UPDATE list = ?,contact = ?.... -
这个想法是不要更改表中已有的记录。在任何情况下,失败都不是因为存在重复:运行查询时表中没有具有相同键的记录。
-
但我还是不明白...
on key duplicate update主要用于当您也将 id 作为参数传递时,例如:INSERT INTO cl(id,list, contact) VALUES (?,?, ?) ON DUPLICATE KEY UPDATE cl.id = cl.id...您没有传递 id,并且如果 id 也是自动递增的,那么您永远不应该到达 on dup 密钥更新部分..... -
由于联系人和列表上的唯一索引而命中列表和联系人的唯一组合时达到重复。
-
Mmmmm....还不清楚....顺便说一句,这句话在文档上看起来很有趣:
It is not recommended to use this statement on tables with more than one unique index.....
标签: java mysql sql jdbc mariadb