SQL Sever 方式做牛客SQL的题目--SQL220

----SQL220 汇总各个部门当前员工的title类型的分配数目

汇总各个部门当前员工的title类型的分配数目,即结果给出部门编号dept_no、dept_name、其部门下所有的员工的title以及该类型title对应的数目count,结果按照dept_no升序排序,dept_no一样的再按title升序排序 ;

输出顺序:dept_no dept_name title count

表的创建及数据从插入:

sql 复制代码
drop table if exists  departments ;
drop table if exists  dept_emp ;
drop table if exists  titles ;
CREATE TABLE departments (
dept_no char(4) NOT NULL,
dept_name varchar(40) NOT NULL,
PRIMARY KEY (dept_no));
CREATE TABLE dept_emp (
emp_no int NOT NULL,
dept_no char(4) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL,
PRIMARY KEY (emp_no,dept_no));
CREATE TABLE titles (
emp_no int NOT NULL,
title varchar(50) NOT NULL,
from_date date NOT NULL,
to_date date DEFAULT NULL);
INSERT INTO departments VALUES('d001','Marketing');
INSERT INTO departments VALUES('d002','Finance');
INSERT INTO dept_emp VALUES(10001,'d001','1986-06-26','9999-01-01');
INSERT INTO dept_emp VALUES(10002,'d001','1996-08-03','9999-01-01');
INSERT INTO dept_emp VALUES(10003,'d002','1995-12-03','9999-01-01');
INSERT INTO titles VALUES(10001,'Senior Engineer','1986-06-26','9999-01-01');
INSERT INTO titles VALUES(10002,'Staff','1996-08-03','9999-01-01');
INSERT INTO titles VALUES(10003,'Senior Engineer','1995-12-03','9999-01-01');

查询思路:

① 所查数据涉及三表,需要三表连接查询 - join

② 统计title的个数,需要使用Count( )函数

③ 各个部门当前员工的title类型,需要对部门号和title分组

查询:

sql 复制代码
select d.dept_no,dept_name,title,count(title) as count
from departments d
join dept_emp de on d.dept_no = de.dept_no
join titles t on de.emp_no = t.emp_no
group by d.dept_no,dept_name,title
order by d.dept_no,title
相关推荐
夏贰四4 分钟前
数据转换的本质是什么?数据转换适配哪些业务场景?
大数据·数据库·数据转换
zzhongcy14 分钟前
Flyway 分工方案(DBA 执行 + 应用只读校验)
数据库·oracle
小短腿的代码世界14 分钟前
Qt布局系统源码深度解析:QLayout如何操控你的界面——从QBoxLayout到QGridLayout的底层引擎揭秘
开发语言·数据库·qt
青云计划19 分钟前
数据库的ID的另一种选择-雪花算法
数据库·算法
YL2004042622 分钟前
MySQL-进阶篇-视图/存储过程/触发器
数据库·mysql
qq_4017004122 分钟前
Qt 中使用 SQLite 数据库以及数据库连接池的设计与实现
数据库·qt·sqlite
arronKler25 分钟前
数据库性能优化三:程序操作优化
数据库·oracle
墨着染霜华26 分钟前
MySQL字符串数字筛选与转换 + Java Integer/Long数值长度避坑指南
java·数据库·mysql
2401_8504916530 分钟前
Bootstrap和OpenLayers结合开发的示例
jvm·数据库·python
Royzst31 分钟前
集合进阶(Map集合)
java·前端·数据库