文章详情页
mysql - INSERT ON DUPLICATE KEY 是如何判断重复key的?
浏览:225日期:2022-06-14 18:52:24
问题描述
使用INSERT的时候 有表T(id,A,B,C,D)
插入的时候希望通过A,B索引唯一记录 ,有重复的时候更新C,D
INSERT INTO T(A,B,C,D) VALUES (a,b,c,d) ON DUPLICATE KEY UPDATE C=C+1,D=d 居然是可用的
INSERT 和UPDATE都是正常的
只是不知道有没有其他问题
所以 MySQL到底是如何判断DUPLICATE KEY的?
问题解答
回答1:这条语句相当于:
INSERT INTO ... VALUES ...
当INSERT(因为主键或唯一键冲突)失败时,执行
UPDATE ... SET ... WHERE A = a AND B = b
只是这个过程用一个原子语句来实现罢了,具体可参阅MySQL的官方文档: https://dev.mysql.com/doc/ref...
如果表中有多个唯一键,情况就更复杂了,有兴趣可以深入研究。还有一个类似的语句叫 REPLACE 跟INSERT ... ON DUPLICATE KEY UPDATE作用类似,但原理是不一样的,有兴趣可参阅: https://dev.mysql.com/doc/ref...
相关文章:
1. vim - docker中新的ubuntu12.04镜像,运行vi提示,找不到命名.2. docker网络端口映射,没有方便点的操作方法么?3. 为什么我ping不通我的docker容器呢???4. debian - docker依赖的aufs-tools源码哪里可以找到啊?5. docker-compose 为何找不到配置文件?6. mac连接阿里云docker集群,已经卡了2天了,求问?7. golang - 用IDE看docker源码时的小问题8. java - 一个泛型标签问题9. java类中的成员成员变量赋值之后什么时候会被回收,有什么办法监听到某一个对象被回收吗10. yii2中restful配置好后在nginx下报404错误
排行榜

网公网安备