当前位置:首页 > 开发 > 数据库 > 正文

插入表主键冲突做更新

发表于: 2015-07-19   作者:a-john   来源:转载   浏览:
摘要: 有以下场景: 用户下了一个订单,订单内的内容较多,且来自多表,首次下单的时候,内容可能会不全(部分内容不是必须,出现有些表根本就没有没有该订单的值)。在以后更改订单时,有些内容会更改,有些内容会新增。 问题: 如果在sql语句中执行update操作,在没有数据的表中会出错。如果在逻辑代码中先做查询,查询结果有做更新,没有做插入,这样会将代码复杂化。 解决: mysql中提供了一个sql语

有以下场景:

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

问题:

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

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
Hibernate 创建表 1,首先数据库必须存在,然后在数据库中创建表(使用hibernate) 2,创建配置文件h
在使用MyBatis进行开发的过程中,当你遇到向某张数据库表中插入一条记录时,出现数据插入不正确,如
众所周知,sqlite3是ios数据存储其一,具体优点和缺点,我就不再赘述,请大家搜索之。 一、必备条件
[MySQL FAQ]系列 — 为什么InnoDB表要建议用自增列做主键 http://imysql.com/2014/09/14/mysql-faq-
我们先了解下InnoDB引擎表的一些关键特征: InnoDB引擎表是基于B+树的索引组织表(IOT); 每个表都需
上篇文章哈希查找因何快?我们使用它需要付出什么代价只是简单介绍了使用hash所带来的利与弊。并未
  在数据库的设计中我们常常用Guid或int来做主键,根据所学的知识一直感觉int做主键效率要高,但
原文连接:http://www.cnblogs.com/jackhuclan/archive/2010/01/04/1639005.html 在数据库的设计中
如何才能把Excel中的数据导入Orcale中呢? 本文提供一种间接的思路: 利用Sql Server和Excel的近亲
原文链接:http://www.cnblogs.com/lyhabc/p/3776000.html 将多行查询结果插入到表中 语法 INSERT I
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号