我正在尝试编写一个SQL语句,该语句输出一个表,其中两列显示名称和季节数。 show列必须不包含duplocates,season列数会计算与show entity关联的季节数。
以下是我的两张表
显示表格
id |名称
季节表
id | show_id | season_number
这是我到目前为止所尝试的内容
SELECT DISTINCT shows.name
FROM shows
INNER JOIN seasons on show.id = seasons.show_id;
以上代码适用于抓取不同的名称,但每当我尝试添加COUNT(season.id)时,它就会中断
有什么建议?
谢谢!
答案 0 :(得分:0)
使用group by
将具有相同名称的多个行聚合到一个组中。使用count(distinct id)
,您可以计算该组中id列的不同值的数量。
SELECT name
, COUNT(DISTINCT seasons.id)
FROM shows
JOIN seasons
ON shows.show_id = seasons.show_id
GROUP BY
name
顺便说一下,我期待一个季节有一对多的关系来展示,而不是相反。