zoukankan      html  css  js  c++  java
  • mysql之replace into与 insert into duplicat key for update

      mysql实际应用中,我们在插入数据的时候,经常遇到主键冲突的情况,这是因为库中已经存在相同主键的数据,这时,我们只能更新数据;在判断是更新数据还是插入数据,我们还需要在此之前做一些必要的判断;在mysql中有没有一种集插入更新于一体的方法呢,答案是有,这就是insert  into 的加强版replace into 

    tableName values()和insert into tableName  values()  on duplicat key  update  ...

      


     1.创建测试表并插入数据

      create table replaceTest(
        id int not null auto_increment,
        name varchar(20) ,
        addr varchar(100),
        primary key (id)
      )charset = utf8

      -- 插入数据

      insert into replaceTest values(null,'aa','bbbbbb'),(null,'cc','ddddd'),(null,'ee','fffff');

    2.replace into 是insert into 的加强版,既可以更新数据也可以插入数据;它的执行逻辑是:首先判断是否存在相同的唯一主键或者唯一索引,如果存在,在更新数据,否则,插入数据,例如:

      

      之所以会是2行数据受到影响,是因为表中已存在主键为1的数据,mysql先将原有的数据删除,并将新的数据插入,因此受影响的是2行数据

      在看下面的例子:

      

      查询结果,说明是先删除后插入:

      

    3.insert into  on duplicat key udpate 和replace into 类似,也是可以插入和更新,它们的不同点是,insert into 只更新update后面的字段。

    4.总结:如果存在相同的主键或唯一索引,replace into 相当于先删除数据而后在插入,如果不存在相同的主键和唯一索引,则直接插入。

        如果存在相同的主键或唯一索引,insert into  on duplicate key update只更新update后面的字段,相当于udpate ;如果不存在相同的主键或唯一索引,则直接插入

      

      

      

      

      

      

      

      

  • 相关阅读:
    ASP.Net控件基础篇
    ASP.Net
    有关于静态
    重载
    继承和多态
    面向对象的封装
    .net webform 把word转为html
    lambda 表达式 比较时间大小
    js 根据名字获取cookie 的方法
    .net 常用的命名空间和类
  • 原文地址:https://www.cnblogs.com/wqk66/p/10749283.html
Copyright © 2011-2022 走看看