题目:
获取所有非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