设为首页 收藏本站
查看: 236|回复: 0

[经验分享] 浅谈unique列上插入重复值的MySQL解决方案

[复制链接]

尚未签到

发表于 2016-10-17 06:48:25 | 显示全部楼层 |阅读模式
  本文的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 |  

  • +----+----------+---------------+  

  • 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 |  

  • +----+----------+---------------+  

  • 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 |  

  • +----+------------+----------------+  

  • rows in set (0.01 sec) 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-287097-1-1.html 上篇帖子: mysql 高版本jdbc驱动程序使用PreparedStatement.setBinaryStream方法报错及解决办法 下篇帖子: 在Windows Vista上安装Ruby on Rails和配置MySQL
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表