mysql中replaceinto与insertinto区别
短信预约 -IT技能 免费直播动态提醒
replace into 遇到主键或唯一索引冲突时,会先删除数据,再插入新数据
insert into 遇到主键或唯一索引冲突时,会直接报错,不插入数据
案例:
新建一个test表,三个字段,id,title,uid, id是自增的主键,uid是唯一索引;
CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(255) DEFAULT NULL,
`uid` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `sss` (`uid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
插入2条数据
insert into test(title,uid) VALUES ('张三','001');
insert into test(title,uid) VALUES ('张三','002');
使用 insert into插入数据时,报错
insert into test(title,uid) VALUES ('李四','001');
使用 replace into插入数据时:
replace into test(title,uid) VALUES ('李四','001');
replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2. 否则,直接插入新数据。
要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replace into 会直接插入数据,这将导致表中出现重复的数据。
到此这篇关于mysql中replace into与insert into区别的文章就介绍到这了,更多相关mysql replace into与insert into内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341