此为博主(yjclsx)原创文章,如若转载请标明出处,谢谢!
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。
不同点:
存在冲突的时候,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 (col1,col2) values ('v1','v2'),('v3','v4'),('v5','v6');
这个效果提升地很明显,以前地区表有几万条数据,一条条insert要几分钟,用了批量插入values,瞬间就完成了!
2、删除MySQL的索引,有索引的存在,插入速度会受很大的影响。
此为博主(yjclsx)原创文章,如若转载请标明出处,谢谢!