表: Employee
±—±-------+ | Id | Salary | ±—±-------+ | 1 | 100 | | 2 | 200 | | 3 | 300 | ±—±-------+ Id是上表主键
例如上述 Employee 表,SQL查询应该返回 200作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null
+---------------------+ | SecondHighestSalary | +---------------------+ | 200 | +---------------------+将不同的薪资按降序排序,然后使用 LIMIT子句获得第二高的薪资。
SELECT DISTINCT Salary AS SecondHighestSalary FROM Employee ORDER BY Salary DESC LIMIT 1 OFFSET 1然而,如果没有这样的第二最高工资,这个解决方案将被判断为 “错误答案”,因为本表可能只有一项记录。为了克服这个问题,我们可以使用IFNULL
SELECT IFNULL( (SELECT DISTINCT Salary FROM Employee ORDER BY Salary DESC LIMIT 1 OFFSET 1), NULL) AS SecondHighestSalaryIFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
IFNULL() 函数语法格式为:
IFNULL(expression, alt_value)