mysql中replace into与insert into区别
2023-01-18 10:08:06 来源:易采站长站 作者:
replaceinto遇到主键或唯一索引冲突时,会先删除数据,再插入新数据insertinto遇到主键或唯一索引冲突时,会直接报错,不插入数据案例:新建一个test表,三个字段,id,titl...
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内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
如有侵权,请发邮件到 [email protected]
最新图文推荐
相关文章
-
MySQL 创建数据库 我们可以在登陆 MySQL 服务后,使用 create 命令创建数据库,语法如下: CREATE DATABASE 数据库名; 以下命令简单的演示了创建数据库的过程,数据名为 RUNOOB: [[email protected]]# mysql2020-07-01
-
mysql 加了 skip-name-resolve不能链接数据库问题的解决方法
mysql 加了 skip-name-resolve不能链接的问题, 要确认 MySql 是否采用过主机名的授权 在 MySql Server 的配置文件 My.ini 中,增加如下两行: [mysqld] skip-name-resolve 它将禁止 MySql Server 对外部连接进2019-01-04