MySQL多表查询语句

发布于 2024年08月11日
-- 1. 查出至少有一个员工的部门。显示部门编号、部门名称、部门位置、部门人数。
SELECT 
	a.deptno, a.dname, a.loc, b.ct  
FROM 
	`dept` a, (SELECT deptno, COUNT(1) ct FROM `emp` GROUP BY `deptno`) b 
WHERE 
	a.deptno = b.deptno;
-- 2. 列出薪金比周星驰高的所有员工。
SELECT * 
FROM `emp` 
WHERE IFNULL(`comm`,0) + `sal` > (SELECT sal+IFNULL(comm,0) FROM `emp` WHERE `ename` = '周星驰');
-- 3. 列出所有员工的姓名及其直接上级的姓名。
SELECT a.`ename` '员工姓名' , b.`ename` '上级姓名'
FROM `emp` a , `emp` b
WHERE a.`mgr` = b.`empno`;
-- 4. 列出受雇日期早于直接上级的所有员工的编号、姓名、部门名称。
SELECT m.`empno`, m.`ename`, d.`dname`
FROM `emp` m, `emp` n ,`dept` d
WHERE m.mgr = n.empno AND m.hiredate < n.hiredate AND m.deptno = d.deptno;
-- 5. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
SELECT d.dname, e.* 
FROM `emp` e
RIGHT JOIN `dept` d 
ON e.deptno = d.deptno;
-- 6. 列出所有文员的姓名及其部门名称,部门的人数。
SELECT a.`ename` ,c.dname ,b.ct
FROM `emp` a ,(SELECT deptno, COUNT(1) ct FROM `emp` GROUP BY `deptno`) b , `dept` c
WHERE a.deptno = b.deptno AND b.deptno = c.deptno AND a.`job` = '文员'; 
-- 7. 列出最低薪金大于15000的各种工作及从事此工作的员工人数。
SELECT `job`, COUNT(1) FROM `emp` GROUP BY `job` HAVING MIN(`sal`+IFNULL(`comm`,0)) > 15000;
-- 8. 列出在研发部工作的员工的姓名,假定不知道研发部的部门编号。
SELECT `ename` FROM `emp` WHERE `deptno` = (SELECT `deptno` FROM `dept` WHERE `dname` = '研发部');
-- 9. 列出薪金高于公司平均薪金的所有员工信息,所在部门名称,上级领导,工资等级。
-- 高于公司平均薪金
-- 部门名称,上级领导,工资等级

SELECT a.*, b.ename, c.dname, d.grade
FROM `emp` a 
LEFT JOIN `emp` b
ON a.`mgr` = b.empno
LEFT JOIN `dept` c
ON a.`deptno` = c.deptno
LEFT JOIN `salgrade`d
ON a.`sal` BETWEEN d.`losal` AND d.`hisal`
WHERE a.`sal` > (SELECT AVG(`sal`) FROM `emp`);

-- 10.列出与Tom从事相同工作的所有员工及部门名称。
SELECT a.`ename`, b.`dname`
FROM `emp` a, `dept` b
WHERE a.`job` = (SELECT `job` FROM `emp` WHERE `ename` = 'TOM') 
AND a.`deptno` = b.`deptno`;


-- 11.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金、部门名称。
-- 员工姓名和薪金、部门名称
SELECT a.`ename`, a.`sal`+IFNULL(a.`comm`,0), b.dname
FROM `emp` a
LEFT JOIN `dept` b
ON a.`deptno` = b.`deptno`
WHERE a.`sal`+IFNULL(a.`comm`,0) >ALL(SELECT `sal`+IFNULL(`comm`,0) FROM `emp` WHERE `deptno` = 30);

-- 12.列出每个部门的员工数量、平均工资。
SELECT a.`dname`, b.`ct`, b.`ag`
FROM `dept` a
LEFT JOIN (SELECT deptno, COUNT(1) ct, AVG(`sal`) ag FROM `emp` GROUP BY `deptno`) b
ON a.`deptno` = b.`deptno`;



评论