access SQL 如何实现查询表A中字段在表B中出现次数 包括0次
现有一条SQL是这样的Account表ID,帐号1,test2,test1Groups表ID,所属帐号1,test执行SQL后SELECTa.帐号,COUNT(1)FRO...
现有一条SQL是这样的
Account表
ID, 帐号
1, test
2, test1
Groups表
ID, 所属帐号
1, test
执行SQL后
SELECT a.帐号, COUNT(1) FROM Account a, Groups g WHERE a.帐号 = g.所属帐号 GROUP BY a.帐号
显示的是
test 1
而我希望显示的是
test 1
test1 0
我那条只能查询匹配到的数据,匹配不到的就忽略了,希望能以Account表为基础,把Account表中帐号字段在Groups表中出现的次数都查询出来,包括0次
该如何写SQL呢? 展开
Account表
ID, 帐号
1, test
2, test1
Groups表
ID, 所属帐号
1, test
执行SQL后
SELECT a.帐号, COUNT(1) FROM Account a, Groups g WHERE a.帐号 = g.所属帐号 GROUP BY a.帐号
显示的是
test 1
而我希望显示的是
test 1
test1 0
我那条只能查询匹配到的数据,匹配不到的就忽略了,希望能以Account表为基础,把Account表中帐号字段在Groups表中出现的次数都查询出来,包括0次
该如何写SQL呢? 展开
2个回答
展开全部
这个需求可以用左连接实现,sql语句如下:
1)如果Groups.账号是唯一的
select a.账号,count(b.账号) as 次数 from
Acounts a left join Groups b on a.账号=b.账号
group by a.账号;
2)如果Groups.账号是非唯一的
select a.账号,count(b.账号) as 次数 from
Acounts a left join
(select distinct 账号 from Groups) b
on a.账号=b.账号 group by a.账号;
1)如果Groups.账号是唯一的
select a.账号,count(b.账号) as 次数 from
Acounts a left join Groups b on a.账号=b.账号
group by a.账号;
2)如果Groups.账号是非唯一的
select a.账号,count(b.账号) as 次数 from
Acounts a left join
(select distinct 账号 from Groups) b
on a.账号=b.账号 group by a.账号;
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询