mysql中replace into与insert into区别

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 会直接插入数据,这将导致表中出现重复的数据。

作者:帅成一匹马 原文地址:https://blog.csdn.net/shenshengsu1990/article/details/122730923

%s 个评论

要回复文章请先登录注册