插入表主键冲突做更新
编程技术  /  houtizong 发布于 3年前   137
有以下场景:
用户下了一个订单,订单内的内容较多,且来自多表,首次下单的时候,内容可能会不全(部分内容不是必须,出现有些表根本就没有没有该订单的值)。在以后更改订单时,有些内容会更改,有些内容会新增。
问题:
如果在sql语句中执行update操作,在没有数据的表中会出错。如果在逻辑代码中先做查询,查询结果有做更新,没有做插入,这样会将代码复杂化。
解决:
mysql中提供了一个sql语句:insert into ... on duplicate key update,比如:
insert into user(name,age) values (#{name},#{age}) on duplicate key update name = #{name},age = #{age}
这里是先做插入,如果主键没有冲突,那么插入成功;如果主键已经存在引起冲突,那么会执行后面的update操作。
并且可以对update的语句做判断:
insert into user(name,age) values(#{name},#{age}) on duplicate key update name = IF(#{name}!='',#{name},name),age=IF(#{age}>0,#{age},age)
判断的语法:IF(expr1,expr2,expr3),若expr1为true,则选择expr2,若expr1位false,则选择expr3
另外 expr1如果判断是否为null,(#{name} != null,#{name},name),不管name是不是null,都会执行expr3。如果要判断是否为null,可以用:
IFNULL(expr1,expr2)
expr1若为null,则选expr2,;不为null,则选expr1
请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!
技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成
网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];
文章归档
文章标签
友情链接