加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql必读Mysql中 unique列插入重复值该怎么解决呢

发布时间:2020-12-12 02:26:40 所属栏目:MySql教程 来源:网络整理
导读:《Mysql必读Mysql中 unique列插入重复值该怎么解决呢》要点: 本文介绍了Mysql必读Mysql中 unique列插入重复值该怎么解决呢,希望对您有用。如果有疑问,可以联系我们。 当unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情

《Mysql必读Mysql中 unique列插入重复值该怎么解决呢》要点:
本文介绍了Mysql必读Mysql中 unique列插入重复值该怎么解决呢,希望对您有用。如果有疑问,可以联系我们。

当unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情况:使用IGNORE关键字或者ON DUPLICATE KEY UPDATE子句跳过INSERT、中断操作或者更新旧记录为新值.MYSQL数据库

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,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数据库

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数据库

mysql> insert ignore into menus(id,'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都回跳过它(而不是放弃全部操作).MYSQL数据库

在这种情况下,我们还可以通过添加MySQL4.1新增加的ON DUPLICATE KEY UPDATE子句,使MySQL自动把INSERT操作转换为UPDATE操作.这个子句必须具有需要更新的字段列表,这个列表和UPDATE语句使用的列表相同.MYSQL数据库

mysql> insert into menus(id,'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数据库

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) 

以上内容是小编给大家介绍的Mysql中 unique列插入重复值该怎么办理的全部教程,希望对大家有所帮助.MYSQL数据库

编程之家PHP培训学院每天发布《Mysql必读Mysql中 unique列插入重复值该怎么解决呢》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读