加入收藏 | 设为首页 | 会员中心 | 我要投稿 92站长网 (https://www.92zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql数据库添加数据语句怎么写_mysql中多种插入数据的语句

发布时间:2022-10-13 02:01:02 所属栏目:MySql教程 来源:互联网
导读: 摘抄自:
mysql中常用的三种插入数据的语句
insert into表示插入数据,数据库会检查主键,如果出现重复会报错;
replace into表示插入替换数据,需求表中有PrimaryKey,或者unique索引,如

摘抄自:

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的索引,有索引的存在MySQL 插入数据,插入速度会受很大的影响。

(编辑:92站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!