目录
语法
SELECT DISTINCT column1, column2, ...
SELECT DISTINCT
语句用于返回唯一不同的值。SELECT DISTINCT
后面跟着想要获取唯一值的列名,列名之间用逗号分隔。当从数据库表中查询数据时,如果表中某列包含重复的值,而又只想获取这些值的唯一列表,那么就可以使用 DISTINCT
关键字。
如果对多个列使用 DISTINCT
,那么 SQL 会返回这些列组合起来的唯一值。这意味着只有当所有指定的列组合起来的结果完全相同时,这些行才会被视为重复并被 DISTINCT
排除。
LIMIT
xOFFSET
x
在SQL查询中,LIMIT
和 OFFSET
子句通常一起使用来限制查询结果的数量,并指定从哪里开始获取这些结果。这种组合特别有用于分页显示查询结果。
LIMIT
子句用于指定希望从查询结果集中返回的记录数。OFFSET
子句用于指定在开始返回记录之前要跳过的记录数。
以LIMIT 1 OFFSET 1
为例,意思是:跳过第一条记录(OFFSET 1
),然后返回接下来的1条记录(LIMIT 1
)。这通常用于获取查询结果的第二行数据(假设结果集是按某种顺序排列的,比如按主键或某个特定的列排序)。
在某些数据库系统中(如SQL Server),可能需要使用不同的语法来实现分页,比如 ROW_NUMBER()
函数结合 OVER()
子句,或者使用 OFFSET FETCH
子句。
需求
Employee
表:
+-------------+------+
| Column Name | Type |
+-------------+------+
| id | int |
| salary | int |
+-------------+------+
id 是这个表的主键。
表的每一行包含员工的工资信息
查询并返回 Employee
表中第二高的 不同 薪水 。如果不存在第二高的薪水,查询应该返回 null(Pandas 则返回 None)
。
示例
示例 1:
输入:
Employee 表:
+----+--------+
| id | salary |
+----+--------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
+----+--------+
输出:
+---------------------+
| SecondHighestSalary |
+---------------------+
| 200 |
+---------------------+
示例 2:
输入:
Employee 表:
+----+--------+
| id | salary |
+----+--------+
| 1 | 100 |
+----+--------+
输出:
+---------------------+
| SecondHighestSalary |
+---------------------+
| null |
+---------------------+
分析
一个表,Employee 表,包含id和薪水
两个条件,查询并返回 Employee 表中第二高的 不同 薪水,第二高和不同两个条件
查询不同的薪水可以通过distinct实现,select distinct Salary
第二高通过order by降序排列结合limit实现,order by Salary desc
对于降序排列的结果,仅需要取第二个,通过limit+offset实现
仅取结果的的第二个,即跳过现有第一行后取一行,limit 1 offset 1
还需要解决一个特殊情况,如果不存在第二高的薪水,查询应该返回 null(Pandas 则返回 None) 。
可以考虑使用 ifNull(查询,null)方法,或者通过外层再加一层查询,使其作为临时表
select( select distinct Salary from Employee order by Salary desc limit 1 offset 1) as SecondHighestSalary
代码
select
(
select distinct Salary
from Employee
order by Salary desc
limit 1 offset 1
) as SecondHighestSalary