mysql重复插入insert时ON DUPLICATE KEY UPDATE

本文探讨了SQL中on duplicate key update语法的使用场景及其优势。当需要处理大量数据并避免重复插入时,该语法可以简化操作流程,无需在业务层进行额外的唯一键检查。文中还提供了官方文档链接以便读者深入学习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天一朋友问我SQL一个问题

问题如下


其实他就是想插入时用的 count(1) 下面update怎么用

虽然 on duplicate key update 我没用过

不过经常sql打交道也知道下面如果想用肯定需要再次查询一遍这个

一般都是后台传的参数谁让你用sql处理业务

上方count(1) 是写在查询里的而且应该也没法直接用来使用

好的翻篇处于没有使用过的东西 我的态度一致好奇害死猫 研究去.....


on duplicate key update 的使用我去查了下

处理很多大数据量插入重复数据有唯一键时使用

常规写法(不使用 on duplicate key update情况):

            在业务层先判断唯一键是否存在 存在更新 不存在插入

on duplicate key update可以省略这种麻烦的写法

关于解释:

如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE

官方解释:

https://dev.mysql.com/doc/refman/8.0/en/insert-on-duplicate.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值