当前位置:  开发笔记 > 编程语言 > 正文

使用嵌套的group-by/having子句进行复杂连接?

如何解决《使用嵌套的group-by/having子句进行复杂连接?》经验,为你挑选了1个好方法。

我最终需要一个"导入"记录列表,其中包括"专辑"记录,每个记录只有一首"歌曲".

这就是我现在使用的:

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)
);

嵌套的select(带连接)非常快,但外部的"in"子句非常缓慢.

我试图使整个查询成为单个(无嵌套)连接,但遇到了group/having子句的问题.我能做的最好的是带有欺骗的"导入"记录列表,这是不可接受的.

是否有更优雅的方式来撰写此查询?



1> achinda99..:

这个怎么样?

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; 

在大多数数据库系统中,JOIN的工作速度比执行WHERE ... IN要快.

推荐阅读
mobiledu2402851203
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有