gpt4 book ai didi

MYSQL 选择另一个表中出现的多个 id 的计数

转载 作者:行者123 更新时间:2023-11-30 23:15:07 25 4
gpt4 key购买 nike

我已经搜索了很多这个问题的答案,但我还没有找到确切的方法。

我的数据库中的三个相关表是 tool、purpose 和 user_tools。工具和目的都有 id 和描述列,而 user_tools 有列user_id、tool_id 和 purpose_id。工具和目的本质上是静态查找表,user_tools 有一行用于给定用户使用工具的每个目的。

我需要构建一个 SELECT 语句,其列是工具描述和用途表中列出的每个不同用途的使用次数。例如。结果行:

description | Purpose: Class | Purpose: Student Club | Purpose: Personal Project | ...

'Lathe' | 100 | 50 | 11 | ...

我希望这样做时不必将 purpose_id 硬编码到 SELECT 中,这样如果我想将新条目添加到 purpose 表中,我就不需要更改我的代码。

以下语句获取我想要的信息,但它会为每个不同的目的计数创建一个新行,我希望将它们全部放在列中。

SELECT 
tool.description,
count(purpose.id),
purpose.description
FROM
user_tools LEFT OUTER JOIN tool
ON
user_tools.tool_id = tool.id LEFT OUTER JOIN purpose
ON
user_tools.purpose_id = purpose.id
GROUP BY
tool.description,
purpose.description

最佳答案

除了编写使用动态 SQL 的过程之外,您还必须针对目的 ID 进行硬编码,因为您不能在查询中拥有不同数量的结果列。

您需要的是 PIVOT 操作。这是在 MySQL 中是如何完成的:

SELECT
tool.description,
COUNT(CASE WHEN purpose.id = <ID for Class> THEN 1 END) AS `Purpose: Class`,
COUNT(CASE WHEN purpose.id = <ID for Student Club> THEN 1 END) AS `Purpose: Student Club`,
. . . and the rest of the purpose.id values
FROM user_tools
LEFT JOIN tool ON user_tools.tool_id = tool.id
LEFT JOIN purpose ON user_tools.purpose_id = purpose_id
GROUP BY tool.description

请注意,此答案基于您的示例查询,而不是您对数据的任何了解。如果答案没有得到您需要的结果,请发布示例数据,我应该能够修改查询以获得您想要的结果。

关于MYSQL 选择另一个表中出现的多个 id 的计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18236076/

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