首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >插入MySQL表或如果存在没有唯一键的update

插入MySQL表或如果存在没有唯一键的update
EN

Stack Overflow用户
提问于 2017-04-09 12:07:30
回答 1查看 158关注 0票数 0

我知道有一种方法可以使用一个唯一的键(例如ID )来实现这个结果,但是正如您在下面的例子中所看到的那样,这是行不通的,因为我没有一个唯一的键。

代码语言:javascript
复制
INSERT INTO User_Status (User_ID1, User_ID2, Status) VALUES(?, ?, ?) ON DUPLICATE KEY UPDATE Status = ?

问题是,我没有一个唯一的ID在这个表上,但是有3个当前的选项。1) Twoo用户没有一种状态,换句话说:将其插入表中。2)用户1与用户2具有一种状态(但是1-2组合是唯一的)。3)与案例2相同,但反过来:用户2与用户1具有一种状态(同样,这种组合是唯一的)。

如果该选项已经存在,是否仍然需要更新?

样本数据:

代码语言:javascript
复制
User_ID1     User_ID2     Status
1            4            has_send_request
4            1            has_received_request
4            2            friends
2            4            friends    

假设我想将用户1-4的状态从has_send_request更新到好友。在这种情况下,我可以做一个正常的更新查询。但是,如果我想从用户2-4更新状态,我需要做一个插入查询,而不是一个更新查询。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-04-09 12:34:05

请参阅附件中的图片如何创建一个独特的钥匙。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43306495

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档