zoukankan      html  css  js  c++  java
  • mysql中多种插入数据的语句

    摘抄自:https://yjclsx.blog.csdn.net/article/details/83898545

    mysql中常用的三种插入数据的语句

    insert into表示插入数据,数据库会检查主键,如果出现重复会报错; 

    replace into表示插入替换数据,需求表中有PrimaryKey,或者unique索引,如果数据库已经存在数据,则用新数据替换,如果没有数据效果则和insert into一样; 

    insert ignore into表示如果已经存在相同的记录,比如主键或者唯一性字段冲突,则忽略当前新数据; 

    还有一种和replace into功能类似的语句:insert into ... on duplicate key update,他们的区别如下。

    Replace into与Insert into ... on duplicate key update的区别

    相同点:

    (1)没有存在冲突的时候,replace into与insert into ... on duplicate key update相同,就是插入一条新的数据,返回的影响行数是1。

    (2)存在冲突的时候,都会用新数据替换老数据,返回的影响行数是2。

    (3)都支持批量更新,当插入的多条数据中有冲突时,会更新其中冲突的那几条。例如 replace into table (col_1,col_2) values ('v1','v2'),('v3','v4'),('v5','v6'); 和 insert into table (col_1,col_2) values ('v1','v2'),('v3','v4'),('v5','v6') on duplicate key update col_1=VALUES(col_1),col_2=VALUES(col_2);

    不同点:

     存在冲突的时候,replace into是delete老记录,然后录入新的记录,所以原有的所有记录会被清除,这个时候,如果replace into语句的字段不全的话,有些原有的字段的值会被自动填充为默认值,

     同时AUTO_INCREMENT的主键会自动+1。 

     而insert into ... on duplicate key update则只执行update标记之后的sql,从表象上来看相当于一个简单的update语句,所以他保留了所有未修改的字段的旧值。

     从底层执行效率上来讲,replace into要比insert into ... on duplicate key update效率要高,但是在写replace into的时候,字段要写全,防止老的字段数据被删除。

     在实际工作中,经常会需要saveOrUpdate的操作,这时候通常使用的是insert into ... on duplicate key update,以保留未修改的数据。

    提高插入性能

    注意,当插入的数据量很大时,为了提高插入的性能:

    1、可以批量插入VALUES,就是一个values跟很多条数据,每条数据用英文逗号隔开,最后一条才用分号,而不是每一次插入都是一条数据。

    如:insert into table (col_1,col_2) values ('v1','v2'),('v3','v4'),('v5','v6');

    这个效果提升地很明显,以前地区表有几万条数据,一条条insert要几分钟,用了批量插入values,瞬间就完成了!

    2、删除MySQL的索引,有索引的存在,插入速度会受很大的影响。

  • 相关阅读:
    【转】ios输入框被键盘挡住的解决办法
    【转】操作系统Unix、Windows、Mac OS、Linux的故事
    mac 下删除非空文件夹
    解决Win7 64bit + VS2013 使用opencv时出现提“应用程序无法正常启动(0xc000007b)”错误
    图的邻接表表示
    图的邻接矩阵表示
    并查集
    05-树9 Huffman Codes及基本操作
    05-树7 堆中的路径
    堆的操作集
  • 原文地址:https://www.cnblogs.com/shujiying/p/13952905.html
Copyright © 2011-2022 走看看