qq_32294231 2017-10-24 07:01 采纳率: 50%
浏览 1109

关于mysql count的用法

我有三个表:
provinces: 主键:provinceid ,province
cities: 主键:cityid,city, 外键:provinceid
areas:主键:areaid,area,外键:cityid
其实就是全国省市县区的数据库,我想要查询:

1.查询每个city的area个数
我尝试着用:
select c.city as '市',a.area,count('市')as '区县的数量' from cities c left join areas a using(cityid) group by c.city;
但是有些city是没有area的,例如东莞 中山等等,因为我用的是left join,没有area的会显示为null,但是由于group by,就算东莞 中山等地的area为null,查询出的结果东莞 中山等地区县的数量还是显示为1,该怎么写语句才能使某些没有area的city的area的数量为0

2.查询出每个province的city和area的个数

  • 写回答

2条回答 默认 最新

  • 一只小T 2017-10-24 08:07
    关注
    1. select c.city as '市',(select count(a.areaid) from areas a where a.areaid = c.cityid ) from city c
    评论

报告相同问题?

悬赏问题

  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型
  • ¥15 求学软件的前人们指明方向🥺