gpt4 book ai didi

sql - 我需要做一个子查询

转载 作者:行者123 更新时间:2023-12-04 20:56:56 25 4
gpt4 key购买 nike

我有两个表:邀请和事件。

我需要在同一个查询中获取事件的名称、每个事件的客人总数和礼物总数(当每个事件为真时)!

像连接两个表(左连接)选择 events.name、count(invitations.guest)、count(invitations.presents when = true) 并按事件分组...

正在查看表格数据...

https://dl.dropbox.com/u/360112/Duda/invitaciones.jpg https://dl.dropbox.com/u/360112/Duda/eventos.jpg

我认为它可以工作,但我没有得到我想要的...

SELECT e.name, count(in.guest) as Guests, (SELECT count(presents) 
FROM watermelon.invitations WHERE presents = true) as Presents
FROM watermelon.events e LEFT JOIN watermelon.invitations in ON e.id = in.event
GROUP BY in.event;

然后我得到:

http://dl.dropbox.com/u/360112/Duda/resultado.jpg

一些建议?请我需要它,我已经厌倦了尝试并得到错误的结果......提前致谢!

最佳答案

听起来您想要这样的东西,使用 COUNTGROUP BYCASE:

SELECT E.Id, 
E.Name,
COUNT(I.Id) TotalGuests,
COUNT(CASE WHEN I.Presents = 'TRUE' THEN 1 END) TotalPresents
FROM Events E
LEFT JOIN Invitations I ON E.Id = I.Event
GROUP BY E.Id, E.Name

我不确定您的 Presents 数据类型,但这应该很接近。还使用 LEFT JOIN 返回所有事件。

关于sql - 我需要做一个子查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15825381/

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