牛客SQL题解 - 获取所有部门当前manager的当前薪水情况

题目描述

获取所有部门当前manager的当前薪水情况,给出dept_no, emp_no以及salary,当前表示to_date='9999-01-01'
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 `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));

输出描述

dept_no emp_no salary
d001 10002 72527
d004 10004 74057
d003 10005 94692
d002 10006 43311
d006 10010 94409

试题详解

使用INNER JOIN内连接dept_manager表和salaries表并限制连接条件为emp_no和to_date字段。代码如下:

SELECT d.dept_no,d.emp_no,s.salary
FROM dept_manager AS d INNER JOIN salaries AS s
ON d.emp_no = s.emp_no
AND d.to_date = '9999-01-01'
AND s.to_date = '9999-01-01';
发布了166 篇原创文章 · 获赞 186 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/qq_36936730/article/details/105157531