基本语法
```sql
FIRST_VALUE(column_name) OVER (
PARTITION BY partition_column_name
ORDER BY sort_column_name [ASC|DESC]
[ROWS|RANGE BETWEEN ...]
)
```
- column_name:你想从每个分区或窗口中取出的那列的名称。
- PARTITION BY partition_column_name:定义了结果集中哪些行会被视为一个分组或“窗口”来进行计算。如果省略,整个结果集将被看作一个大的分区。
- ORDER BY sort_column_name [ASC|DESC]:定义了在每个分区内部如何对行进行排序,以便确定哪个值是“第一个”。
使用场景示例
假设你有一个销唀记录表 `sales`,包含字段 `sale_date`(销售日期)和 `amount`(金额)。如果你想在每一条销售记录旁边显示当天的第一笔销售额,你可以使用 `FIRST_VALUE` 函数如下:
```sql
SELECT sale_date,
amount,
FIRST_VALUE(amount) OVER (
PARTITION BY sale_date
ORDER BY sale_date, amount
) AS first_sale_amount
FROM sales;
```
这个查询会在每行展示对应 `sale_date` 当天的第一笔销售额(假设按金额排序,如果两笔销售发生在同一天但时间不同,则考虑加入时间字段进行精确排序)。
注意事项
- `FIRST_VALUE` 与其他窗口函数一样,在处理大数据量时可能会影响查询性能,因为数据库需要对数据进行分区和排序。
- 它不会更改返回结果的行数;它只是在每行旁边添加了额外的信息。
- 在使用时,合理选择 `PARTITION BY` 和 `ORDER BY` 子句,以确保正确地反映你的需求。
`FIRST_VALUE` 函数提供了一种强大而灵活的方式,用于分析和比较同一分组或窗口内的行,特别适用于需要基于某种排序逻辑识别首个记录的场景。