快捷搜索:

浅谈unique列上插入重复值的MySQL解决方案

本文的unique列上插入重复值办理规划,主要基于MySQL平台。经由过程这些,可以做到一些新的功能和利用。盼望本文能对大年夜家有所赞助。

当unique列在一个UNIQUE键上插入包孕重复值的记录时,我们可以节制MySQL若何处置惩罚这种环境:应用IGNORE关键字或者ON DUPLICATE KEY UPDATE子句跳过INSERT、中断操作或者更新旧记录为新值。

mysql> create table menus(id tinyint(4) not null auto_increment,

-> label varchar(10) null,url varchar(20) null,unique key(id));

Query OK, 0 rows affected (0.13 sec)

mysql> insert into menus(label,url) values('Home','home.html');

Query OK, 1 row affected (0.06 sec)

mysql> insert into menus(label,url) values('About us','aboutus.html');

Query OK, 1 row affected (0.05 sec)

mysql> insert into menus(label,url) values('Services','services.html');

Query OK, 1 row affected (0.05 sec)

mysql> insert into menus(label,url) values('Feedback','feedback.html');

Query OK, 1 row affected (0.05 sec)

mysql> select * from menus;

+----+----------+---------------+

| id | label   | url          |

+----+----------+---------------+

| 1 | Home    | home.html    |

| 2 | About us | aboutus.html |

| 3 | Services | services.html |

| 4 | Feedback | feedback.html |

+----+----------+---------------+

4 rows in set (0.00 sec)

假如现在在unique列插入一条违抗独一约束的记录,MySQL会中断操作,提示掉足:

mysql> insert into menus(id,label,url) values(4,'Contact us','contactus.html');

ERROR 1062 (23000): Duplicate entry '4' for key 'id'

在前面的INSERT语句添加IGNORE关键字时,假如觉得语句违抗了独一约束,MySQL以致不会考试测验去履行这条语句,是以,下面的语句不会返回差错:

mysql> insert ignore into menus(id,label,url) values(4,'Contact us','contactus.html');

Query OK, 0 rows affected (0.00 sec)

mysql> select * from menus;

+----+----------+---------------+

| id | label   | url          |

+----+----------+---------------+

| 1 | Home    | home.html    |

| 2 | About us | aboutus.html |

| 3 | Services | services.html |

| 4 | Feedback | feedback.html |

+----+----------+---------------+

4 rows in set (0.00 sec)

当有很多的INSERT语句必要被顺序地履行时,IGNORE关键字就使操作变得很方便。应用它可以包管不管哪一个INSERT包孕了重复的键值,MySQL都回跳过它(而不是放弃整个操作)。

在这种环境下,我们还可以经由过程添加MySQL4.1新增添的ON DUPLICATE KEY UPDATE子句,使MySQL自动把INSERT操作转换为UPDATE操作。这个子句必须具有必要更新的字段列表,这个列表和UPDATE语句应用的列表相同。

mysql> insert into menus(id,label,url) values(4,'Contact us','contactus.html')

-> on duplicate key update label='Contact us',url='contactus.html';

Query OK, 2 rows affected (0.05 sec)

在这种环境下,假如MySQL发明表已经包孕具有相同独一键的记录,它会自动更新旧的记录为ON DUPLICATE KEY UPDATE从句中指定的新值:

mysql> select * from menus;

+----+------------+----------------+

| id | label     | url           |

+----+------------+----------------+

| 1 | Home      | home.html     |

| 2 | About us  | aboutus.html  |

| 3 | Services  | services.html |

| 4 | Contact us | contactus.html |

+----+------------+----------------+

4 rows in set (0.01 sec)

您可能还会对下面的文章感兴趣: