SELECT s.emp_no,salary,last_name,first_name
FROM employees as e
JOIN salaries as s
ON s.emp_no=e.emp_no
WHERE salary=(SELECT MAX(salary) FROM salaries WHERE salary<(SELECT MAX(salary) FROM salaries))
#这个题还挺有意思的,题的关键就是怎么筛选出薪水第二多。可以尝试用MAX函数,毕竟可以找到第一大的。首先我们找到工资最高的,如果将此变出一个表,再SELECT查这个表没有意义。我们可以将最高工资变为筛选条件,筛选出小于它的工资,再在小于它的临时工资表中,找到最大的工资,这样就变成了薪水第二高的工资了。