gpt4 book ai didi

mysql - 加入多个ID

转载 作者:太空宇宙 更新时间:2023-11-03 10:48:23 26 4
gpt4 key购买 nike

我一直在帮助一位 friend 解决他的一些 MySQL 查询问题,并想出了这个查询。在写这篇文章时,我有点想知道是否有更好的方法来做到这一点:

select offers.*, users.*, items.* from offers 
join users on users.id = offers.sender_id
join items on
(items.id = offers.receiver_gets_1)
or
(items.id = offers.receiver_gets_2)
or
(items.id = offers.receiver_gets_3)
or
(items.id = offers.receiver_gets_4)
or
(items.id = offers.sender_gets_1)
or
(items.id = offers.sender_gets_2)
or
(items.id = offers.sender_gets_3)
or
(items.id = offers.sender_gets_4)
where receiver_id = 1;

这让我感觉很糟糕,因为我真的觉得我给了他一些乱七八糟的问题(但他并不介意)。这让我想知道是否有更好的方式来写下它?

我试着在谷歌上寻找类似这些问题的东西:
- Mysql Left Join on multiple conditions
- MySQL how to join tables on two fields
- https://dba.stackexchange.com/questions/33996/which-is-better-many-join-conditions-or-many-where-conditions

但这些并没有真正提供任何其他方式。我确实遇到了另一个问题,答案设置与我自己的查询相同。

我知道数据库也许可以建模得更好,但我不应该玩弄它。我不太同意他的表是如何构建的或其他任何东西,但这个问题对我来说仍然很有趣。

最佳答案

您可以使用IN:

select offers.*, users.*, items.* from offers 
join users on users.id = offers.sender_id
join items on
items.id IN (offers.receiver_gets_1, offers.receiver_gets_2, offers.receiver_gets_3, offers.receiver_gets_4,
offers.sender_gets_1, offers.sender_gets_2, offers.sender_gets_3, offers.sender_gets_4)

但是,通常最好设计您的架构,这样您就不会重复列,例如 receiver_gets_1receiver_gets_2,...。相反,您应该有一个关系表中的每一个如果它们在不同的行中,那么你只需要加入它一次就可以得到所有的匹配项。

关于mysql - 加入多个ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27994812/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com