gpt4 book ai didi

mysql - 在 MySQL 中加入一个 Select Distinct 通过连接表重新排序

转载 作者:行者123 更新时间:2023-11-29 00:52:27 25 4
gpt4 key购买 nike

我四处寻找这个问题的答案,但没有找到。我有一个网站,文章存储在文章表中,作者存储在用户表中。我想获得一份作者列表,按他们最近撰写文章的时间排序。

这给了我用户 ID:

SELECT distinct a.user_id 
FROM `article` as a
ORDER BY a.id desc

问题是,一旦我尝试通过加入顺序更改来引入名称,以便按用户 ID 进行排序。我试过这个:

SELECT distinct a.user_id, u.name 
FROM `article` as a
LEFT JOIN user as u on u.id = a.user_id
ORDER BY a.id desc, u.id desc

SELECT distinct a.user_id, u.name 
FROM `article` as a
LEFT JOIN user as u on u.id = a.user_id
ORDER BY u.id desc, a.id desc

但两者都改变​​了名称的顺序。我显然在做一些愚蠢的事情,但是什么?

最佳答案

在您的第一个示例中,DISTINCT 恰好与 ORDER BY 一起使用的事实是侥幸,而不是标准 SQL。你需要这样的东西:

SELECT a.user_id, u.name 
FROM article a
LEFT JOIN user u ON u.id = a.user_id
GROUP BY a.user_id
ORDER BY MAX(a.id) desc

关于mysql - 在 MySQL 中加入一个 Select Distinct 通过连接表重新排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7827664/

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