MySQL“插入…在重复键上”,带有多个唯一键
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL“插入…在重复键上”,带有多个唯一键,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1172字,纯文字阅读大概需要2分钟。
内容图文
我一直在阅读如何在重复键上使用MySQL插入,看看它是否允许我避免选择行,检查它是否存在,然后插入或更新.然而,当我阅读文档时,有一个方面让我感到困惑.这是文档说的:
If you specify ON DUPLICATE KEY UPDATE, and a row is inserted that would cause a duplicate value in a UNIQUE index or PRIMARY KEY, an UPDATE of the old row is performed
问题是,我不想知道这是否适合我的问题,因为我没有插入新条件的’条件’是一个有两列等于某个值的行,不一定主键是相同的.现在我想象的语法是这个,但我不知道它是否总是插入而不是替换:
INSERT INTO attendance (event_id, user_id, status) VALUES(some_event_number, some_user_id, some_status) ON DUPLICATE KEY UPDATE status=1
事实上,event_id和user_id不是主键,但如果表’attendance’中的行已经包含那些具有这些值的列,我只想更新它.否则我想插入它. ON DUPLICATE甚至可以实现这一点吗?如果没有,我可以使用其他什么方法?
解决方法:
如果我是你,我会用event_id和user_id制作一个主键.这将使ON DUPLICATE非常容易.
create table attendance (
event_id int,
user_id int,
status varchar(100),
primary key(event_id, user_id)
);
然后轻松:
insert into attendance (event_id, user_id, status) values(some_event_number, some_user_id, some_status)
on duplicate key
update status = values(status);
内容总结
以上是互联网集市为您收集整理的MySQL“插入…在重复键上”,带有多个唯一键全部内容,希望文章能够帮你解决MySQL“插入…在重复键上”,带有多个唯一键所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。