jihua_usc 2012-09-02 12:18
浏览 222
已采纳

请教一SQL语句

有两个表,
员工表(employee_id(PK),department_id(FK))
部门表(department_name(PK),department_name VARCHAR(50) NOT NULL)

目的是统计各部门下的员工人数,我使用以下
[code="sql"]select
d.department_name,count(1) total
from t_employee t,t_department d
where t.department_id=d.department_name
group by d.department_name
[/code]
语句统计,但得到的是有员工记录的部门统计表
请教,如何统计没有员工记录的部门统计表
???????

  • 写回答

2条回答 默认 最新

  • iteye_15570 2012-09-02 19:29
    关注

    [code="sql"]
    select d.department_name, count(1) as total
    from t_department d left outer join t_employee t
    on t.department_id=d.department_name
    group by d.department_name
    [/code]
    使用左外连接,可以保证即使department没有职员也会被选出.
    如果某一department不喊employee,那么该行total结果则为0.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题