ON DUPLICATE key update的介绍与使用

点赞再看,养成习惯,下面介绍ON DUPLICATE key update的使用。

一、主键索引、唯一索引和普通索引的关系

    主键索引
    在数据库中定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。主键索引不能为空。每个表只能有一个主键

    唯一索引
    不允许两行具有相同的索引值。但可以都为NULL。 如果现有数据中存在重复的键值,则数据库不允许将新创建的唯一索引与表一起保存。当新数据和表中的键值重复时,数据库会拒绝接受此数据。每个表可以有多个唯一索引

    普通索引
    一般的索引结构,可以在条件删选时加快查询效率,索引字段的值可以重复,可以为空值

二、实战操作

1.ON DUPLICATE key update使用介绍:

    有时候由于业务需求,可能需要先去根据某一字段值查询数据库中是否有记录,有则更新,没有则插入。这个时候就可以用到ON DUPLICATE key update这个sql语句了。

2.ON DUPLICATE key update测试样例:

首先创一张简单的表:

 增加以下数据:

  • 数据包含主键(id):

insert into user (id,username,userpwd,num) values (1,"testName","testPwd",10)
ON DUPLICATE KEY UPDATE
username = VALUES(username),
userpwd = VALUES(userpwd)

可以看到是根据主键来判断,如果主键重复则执行update。

  • 加上username为唯一索引之后:

 再次执行

insert into user (id,username,userpwd,num) values (1,"testName2","testPwd2",10)
ON DUPLICATE KEY UPDATE
username = VALUES(username),
userpwd = VALUES(userpwd)

 

可以看到还是根据id来进行判断,如果主键重复则执行update。 

  • 测试没有id时:

insert into user (username,userpwd,num) values ("testName2","testPwd3",10)
ON DUPLICATE KEY UPDATE
username = VALUES(username),
userpwd = VALUES(userpwd)

可以看到,此时是根据唯一索引来进行判断 ,如果唯一索引重复则执行update。

说明优先级:主键>唯一索引

  • 此时测试没有主键和唯一索引重复时的情况:

insert into user (username,userpwd,num) values ("testName4","testPwd4",10)
ON DUPLICATE KEY UPDATE
username = VALUES(username),
userpwd = VALUES(userpwd)

 可以发现,此时是新增一条数据,说明如果主键和唯一索引都不重复的情况执行insert。


三、总结

ON DUPLICATE key update是根据索引字段是否重复来判断是否执行,如果重复则执行update,否则则执行insert。

优先级主键>唯一索引

  • 当主键重复时则执行update
  • 当主键不重复,唯一索引重复时也执行update
  • 当主键和唯一索引值都不重复才执行insert

PS:特殊情况,当主键重复执行update时,如果此时唯一索引字段与其他字段也重复则会报错

 

我是辰兮,你知道的越多,你不知道的越多,我们下期见!

人才们的 【三连】 就是辰兮创作的最大动力,如果本篇博客有任何错误和建议,欢迎人才们留言!

  • 77
    点赞
  • 258
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辰兮ing

您的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值