English 中文(简体)
SQL查询,计数为0
原标题:
  • 时间:2008-08-31 10:39:58
  •  标签:

我有三张表:页、附件、页附件

我有这样的数据:

page
ID    NAME
1     first page
2     second page
3     third page
4     fourth page

attachment
ID    NAME
1     foo.word
2     test.xsl
3     mm.ppt

page-attachment
ID    PAGE-ID   ATTACHMENT-ID
1     2         1
2     2         2
3     3         3

当每页附件数为0时,我也想得到该数。我尝试过:

select page.name, count(page-attachment.id) as attachmentsnumber 
from page 
    inner join page-attachment on page.id=page-id 
group by page.id

我得到的输出是:

NAME        ATTACHMENTSNUMBER
second page  2
third page   1

我想得到这个输出:

NAME        ATTACHMENTSNUMBER
first page   0
second page  2
third page   1
fourth page  0

如何获取0部分?

最佳回答

将“内部联接”更改为“左外部联接”,这意味着“获取联接左侧的所有行,即使右侧没有匹配的行。”

select page.name, count(page-attachment.id) as attachmentsnumber 
from page 
    left outer join page-attachment on page.id=page-id 
group by page.name
问题回答

这里是另一个使用子查询的解决方案。

SELECT
  p.name,
  (
    SELECT COUNT(*) FROM [page-attachment] pa
    WHERE pa.[PAGE-ID] = p.id
  ) as attachmentsnumber
FROM page p

根据数据库的不同,为了提高速度,可以使用UNION命令。

SQL更长,但根据数据库的不同,它通过将“计数存在的东西”和“计数不存在的事情”分开来加快速度。

(
select page.name, count(page-attachment.id) as attachmentsnumber 
from page 
inner join page-attachment on page.id=page-id 
group by page.id
)
UNION
(
select page.name, 0 as attachmentsnumber 
from page
where page.id not in (
    select page-id from page-attachment)
)   

我需要这个解决方案的数据库有20页,有100多万个附件。UNION使它在13秒内运行,而不是太长时间。我感到无聊,尝试了另一种方法(在我杀死外部联接和子查询方法之前的60秒以上)。

您需要一个左联接,而不是一个内部联接,因为这允许记录不存在。

LEFT join is your friend. To learn more about different join types refer to http://en.wikipedia.org/wiki/Join_(SQL)

使用此:

SELECT p.name,(
    SELECT COUNT(*) FROM [page-attachment] pa WHERE pa.[PAGE-ID] = p.id) as attachmentsnumber
FROM page p




相关问题
热门标签