mysql数据库添加数据语句怎么写_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 插入数据,插入速度会受很大的影响。 (编辑:通辽站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |