gpt4 book ai didi

mysql - 如何呈现所有记录

转载 作者:行者123 更新时间:2023-11-29 02:10:12 25 4
gpt4 key购买 nike

我想使用 MYSQL5.5 显示所有记录,方法是将 Count 添加为新列并在 COUNT 中使用特定的 DESC 排序。

示例数据:

ID|ID_2|FIRST|SECOND|
88|300 |1 |4
81|300 |1 |5
7 |300 |2 |1
33|300 |3 |4
99|300 |1 |4
84|300 |1 |5
6 |300 |1 |4
34|300 |3 |5

查询:

SELECT a.ID,a.ID_2, a.FIRST, a.SECOND, COUNT(a.ID) as testing
FROM table AS a
WHERE a.ID_2=300
GROUP BY a.ID_2, a.FIRST, a.SECOND
ORDER BY testing DESC

通过上面的代码,我得到了正确的 COUNT(a.ID) 编号,包括 FIRST 和 SECOND 的所有组合以及 COUNT。

结果:

a.ID|a.ID_2|a.FIRST|a.SECOND|testing|
88 |300 |1 |4 |3
81 |300 |1 |5 |2
7 |300 |2 |1 |1
33 |300 |3 |4 |1
99 |300 |3 |5 |1

但我想得到以下信息:

a.ID|a.ID_2|a.FIRST|a.SECOND|testing|
88 |300 |1 |4 |3
99 |300 |1 |4 |3
6 |300 |1 |4 |3
81 |300 |1 |5 |2
85 |300 |1 |5 |2
7 |300 |2 |1 |1
33 |300 |3 |4 |1
99 |300 |3 |5 |1

你能帮忙吗?即使有临时表。

谢谢你的帮助

最佳答案

使用 MySQL < 8.0,您可以使用计算相关计数的聚合子查询自连接表:

SELECT t.*, t2.testing
FROM
mytable t
INNER JOIN (
SELECT a.ID_2, a.FIRST, a.SECOND, COUNT(a.ID) as testing
FROM mytable a
GROUP BY a.ID_2, a.FIRST, a.SECOND
) t2 ON t.ID_2 = t2.ID_2 AND t.FIRST = t2.FIRST AND t.SECOND = t2.SECOND

关于mysql - 如何呈现所有记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54716840/

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