Tef*_*Ted 1 sql join group-by having
我最终需要一个"导入"记录列表,其中包括"专辑"记录,每个记录只有一首"歌曲".
这就是我现在使用的:
select i.id, i.created_at
from imports i
where i.id in (
select a.import_id
from albums a inner join songs s on a.id = s.album_id
group by a.id having 1 = count(s.id)
);
Run Code Online (Sandbox Code Playgroud)
嵌套的select(带连接)非常快,但外部的"in"子句非常缓慢.
我试图使整个查询成为单个(无嵌套)连接,但遇到了group/having子句的问题.我能做的最好的是带有欺骗的"导入"记录列表,这是不可接受的.
是否有更优雅的方式来撰写此查询?
这个怎么样?
SELECT i.id,
i.created_at
FROM imports i
INNER JOIN (SELECT a.import_id
FROM albums a
INNER JOIN songs s
ON a.id = s.album_id
GROUP BY a.id
HAVING Count(* ) = 1) AS TEMP
ON i.id = TEMP.import_id;
Run Code Online (Sandbox Code Playgroud)
在大多数数据库系统中,JOIN的工作速度比执行WHERE ... IN要快.
| 归档时间: |
|
| 查看次数: |
29668 次 |
| 最近记录: |