题目描述
获取所有非manager的员工emp_no
CREATE TABLE `dept_manager` (
`dept_no` char(4) NOT NULL,
`emp_no` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
解题思路
SELECT emp_no FROM (SELECT * FROM employees LEFT JOIN dept_manager
ON employees.emp_no = dept_manager.emp_no)
WHERE dept_no IS NULL
- 先通过左连接获得结果集,然后查询dept_no 为空的即非manager的员工
本文介绍了一种使用SQL查询技巧来筛选出所有非经理级别的员工的方法。通过左连接(left join)的方式,将employees表与dept_manager表进行关联,再通过where子句筛选出dept_no为空的数据,从而定位到所有非经理级别的员工。这是一种实用的数据库操作技巧,适用于HR信息系统或其他需要区分员工层级的场景。
2558

被折叠的 条评论
为什么被折叠?



