前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ON DUPLICATE KEY UPDATE

ON DUPLICATE KEY UPDATE

作者头像
CBeann
发布2023-12-25 17:12:19
1070
发布2023-12-25 17:12:19
举报
文章被收录于专栏:CBeann的博客CBeann的博客
问题引出

案例:某个餐桌(id)花了多少钱(num)

如果4号餐桌点了一份西红柿4元,我们可以插入;如果3号餐桌点了一份西红柿4元,我们可以修改

你选择insert或者update的原因是你知道他原来有没有数据

如果你不知道呢???

一般我们的逻辑为

先查询,如果没有,插入;反之修改

代码语言:javascript
复制
if not exists (select )
      insert 
else
      update 

最简单直观的问题;发送两条SQL语句吧,性能问题

解决方法

有则改之无则加勉,数据库中同样也有相似的问题,有就修改,没有就插入

ON DUPLICATE KEY UPDATE 就是解决,如果有数据就修改,如果没有数据就插入的问题

第一次执行(数据库中没有id 为4的数据)

代码语言:javascript
复制
INSERT INTO hello (id,num) VALUES (4,4) ON DUPLICATE KEY UPDATE id = 4 ,num = 4+num;

Query OK, 1 row affected

第二次执行(数据库中有id为4的数据)

代码语言:javascript
复制
INSERT INTO hello (id,num) VALUES (4,4) ON DUPLICATE KEY UPDATE id = 4 ,num = 4+num;

Query OK, 2 rows affected

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题引出
  • 解决方法
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档