插入表主键冲突做更新

有以下场景:

用户下了一个订单,订单内的内容较多,且来自多表,首次下单的时候,内容可能会不全(部分内容不是必须,出现有些表根本就没有没有该订单的值)。在以后更改订单时,有些内容会更改,有些内容会新增。

问题:

如果在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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值