• Mysql训练:第二高的薪水(IFNULL,OFFSET,LIMIT)


    编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) 。

    +----+--------+
    | Id | Salary |
    +----+--------+
    | 1  | 100    |
    | 2  | 200    |
    | 3  | 300    |
    +----+--------+

    例如上述 Employee 表,SQL查询应该返回 200 作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null

    +---------------------+
    | SecondHighestSalary |
    +---------------------+
    | 200                 |
    +---------------------+

    方法一:使用子查询和 LIMIT 子句

    将不同的薪资按降序排序,然后使用 LIMIT 子句获得第二高的薪资。

    SELECT DISTINCT
        Salary AS SecondHighestSalary
    FROM
        Employee
    ORDER BY Salary DESC
    LIMIT 1 OFFSET 1

    然而,如果没有这样的第二最高工资,这个解决方案将被判断为 “错误答案”,因为本表可能只有一项记录。为了克服这个问题,我们可以将其作为临时表。

    SELECT
        (SELECT DISTINCT
                Salary
            FROM
                Employee
            ORDER BY Salary DESC
            LIMIT 1 OFFSET 1) AS SecondHighestSalary
    ;

    方法二:使用 IFNULL 和 LIMIT 子句

    解决 “NULL” 问题的另一种方法是使用 “IFNULL” 函数,如下所示。

    SELECT
        IFNULL(
          (SELECT DISTINCT Salary
           FROM Employee
           ORDER BY Salary DESC
            LIMIT 1 OFFSET 1),
        NULL) AS SecondHighestSalary

     ifnull(表达式1,表达式2):它接受两个参数,如果表达式1不是NULL,则返回第一个参数。 否则,IFNULL函数返回第二个参数

  • 相关阅读:
    关于垂直居中
    linux 前后台程序切换
    mac 下jetbrains IDE系列IDE主题
    mac 安装命令行开发者工具
    python 安装MySQLdb mysql_config not fount
    error: command 'cc' failed with exit status 1
    sqllite 入门
    jieba分词
    zookeeper 故障重连机制
    深入学习 celery
  • 原文地址:https://www.cnblogs.com/zwh0910/p/14385702.html
Copyright © 2020-2023  润新知