gpt4 book ai didi

SQL - 'DISTINCT' 仅基于某些列?

转载 作者:行者123 更新时间:2023-12-03 01:49:01 25 4
gpt4 key购买 nike

我有一个包含两个表的数据库。其中一个表包含用户,另一个表包含这些用户的地址。每个用户可能有多个地址(尽管每个地址仅与一个用户绑定(bind)。)

我想创建一个只为每个用户返回一个条目的搜索,即使该用户有多个地址也是如此。搜索拉回哪个地址并不重要 - 搜索首先找到的地址就足够了。

以下是搜索结果示例:

tst  olix  Chicago  IL  USA
tst olix Los Angeles CA USA
tst2 olix2 Houston TX USA

我需要搜索仅返回 2 行,而不是 3 行。

有什么想法吗?

SELECT DISTINCT
Users.Firstname, Users.Surname, Users.UserId,
Users.Recommendations, Addresses.City, Addresses.Region,
Addresses.Country
FROM
Users INNER JOIN
Addresses ON FT_TBL.UserId = Addresses.UserId
ORDER BY
Users.Recommendations

最佳答案

在这种情况下,您可能需要使用 GROUP BY 而不是 DISTINCT

立即发表您的疑问,我将为您提供更多帮助。

或者,如果您只想返回第一个地址,那是完全不同的查询。需要返回地址吗?您需要什么数据?在这种情况下,“第一”意味着什么?数据是如何排序的?

您可以随意执行类似的操作(未经测试),具体取决于您的数据库:

SELECT 
userID
, FIRST(address)
FROM
yourTable
GROUP BY
userID

关于SQL - 'DISTINCT' 仅基于某些列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6792285/

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