sql算法练习——获取非manager员工emp_no

题目:

获取所有非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`));

代码:

方法一:使用NOT IN选出在 employees 但不在 dept_manager 中的 emp_no 记录

1 select employees.emp_no from employees
2 where employees.emp_no not in
3 (select emp_no from dept_manager);

方法二:使用 left join 选择 dept_no 为 null 的值

1 SELECT employees.emp_no FROM employees 
2 LEFT JOIN dept_manager
3 ON employees.emp_no = dept_manager.emp_no
4 WHERE dept_no IS NULL
原文地址:https://www.cnblogs.com/john1015/p/13718942.html