忽略 MySQL INSERT IGNORE 语句,如果表中插入了重复值,则显示错误
mysqlmysqli database
首先我们创建一个表 −
mysql> create table DemoTable ( FirstName varchar(100) ); Query OK, 0 rows impacted (0.58 sec)
正如官方 MySQL 文档中所述,"如果没有 IGNORE,表中重复现有 UNIQUE 索引或 PRIMARY KEY 值的行会导致重复键错误,并且语句被中止"。
因此,现在让我们添加一个唯一索引 −
mysql> alter table DemoTable add unique index(FirstName); Query OK, 0 rows affected (0.50 sec) Records: 0 Duplicates: 0 Warnings: 0
使用 insert 命令在表中插入一些记录。如你所见,由于我们没有使用 INSERT IGNORE,因此在插入重复记录时会出现错误 −
mysql> insert into DemoTable values('Chris'); Query OK, 1 row affected (0.32 sec) mysql> insert into DemoTable values('Robert'); Query OK, 1 row affected (0.09 sec) mysql> insert into DemoTable values('David'); Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable values('Robert'); ERROR 1062 (23000): Duplicate entry 'Robert' for key 'FirstName' mysql> insert into DemoTable values('Chris'); ERROR 1062 (23000): Duplicate entry 'Chris' for key 'FirstName' mysql> insert into DemoTable values('Sam'); Query OK, 1 row affected (0.12 sec)
使用 select 语句显示表中的所有记录 −
mysql> select *from DemoTable;
这将产生以下输出 −
+-----------+ | FirstName | +-----------+ | Chris | | David | | Robert | | Sam | +-----------+ 4 rows in set (0.00 sec)