Apache Doris窗口函数FIRST_VALUE详解:获取分组首值的高效方法
2025-06-27 11:47:27作者:郜逊炳
什么是FIRST_VALUE函数
FIRST_VALUE是Apache Doris中一种强大的窗口函数,它能够在有序的数据窗口分区中返回指定表达式的第一个值。这个函数特别适合需要获取分组数据中首条记录特定字段值的场景,比如分析用户首次购买金额、获取设备首次上报数据等。
函数语法解析
FIRST_VALUE函数的基本语法如下:
FIRST_VALUE(expr[, ignore_null])
参数说明:
expr:必需参数,表示要获取首值的表达式,可以是列名或计算表达式ignore_null:可选布尔参数,当设置为true时,函数会跳过NULL值,返回第一个非NULL值
返回值特性
FIRST_VALUE函数返回值的类型与输入表达式expr的类型完全一致。这意味着如果输入是整数列,返回值也是整数;如果是字符串列,返回值就是字符串。
实际应用示例
让我们通过一个完整的示例来理解FIRST_VALUE的用法:
-- 创建示例数据
WITH example_data AS (
SELECT 1 as id, NULL as value, 'A' as group_name
UNION ALL
SELECT 1, 10, 'A'
UNION ALL
SELECT 1, NULL, 'A'
UNION ALL
SELECT 1, 20, 'A'
UNION ALL
SELECT 2, NULL, 'B'
UNION ALL
SELECT 2, 30, 'B'
UNION ALL
SELECT 2, 40, 'B'
)
-- 使用FIRST_VALUE函数
SELECT
group_name,
id,
value,
FIRST_VALUE(value) OVER (
PARTITION BY id
ORDER BY value NULLS LAST
) AS first_value_default,
FIRST_VALUE(value, true) OVER (
PARTITION BY id
ORDER BY value
) AS first_value_ignore_null
FROM example_data
ORDER BY id, value;
执行结果分析:
+------------+----+-------+---------------------+-------------------------+
| group_name | id | value | first_value_default | first_value_ignore_null |
+------------+----+-------+---------------------+-------------------------+
| A | 1 | NULL | 10 | NULL |
| A | 1 | NULL | 10 | NULL |
| A | 1 | 10 | 10 | 10 |
| A | 1 | 20 | 10 | 10 |
| B | 2 | NULL | 30 | NULL |
| B | 2 | 30 | 30 | 30 |
| B | 2 | 40 | 30 | 30 |
+------------+----+-------+---------------------+-------------------------+
从结果可以看出:
- 默认情况下(不指定ignore_null),函数会按照排序顺序返回第一个值,包括NULL
- 当设置ignore_null为true时,函数会跳过NULL值,返回第一个非NULL值
使用场景建议
FIRST_VALUE函数在以下场景特别有用:
- 用户行为分析:获取用户首次登录时间、首次购买金额等
- 设备监控:记录设备首次上报的异常值
- 金融分析:计算股票交易日的开盘价(当日第一笔交易价格)
- 日志分析:获取错误日志中首次出现的错误代码
性能优化提示
在使用FIRST_VALUE时,考虑以下优化建议:
- 合理使用PARTITION BY子句,避免全表扫描
- 对于大数据集,确保ORDER BY的列上有适当的索引
- 如果只需要非NULL值,使用ignore_null选项可以减少后续处理
- 考虑结合其他窗口函数如LAST_VALUE、NTH_VALUE等实现更复杂的分析需求
通过掌握FIRST_VALUE函数,您可以更高效地处理Apache Doris中的窗口分析任务,提取数据分组中的关键首值信息。
登录后查看全文
热门项目推荐
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00
最新内容推荐
电脑PC网易云音乐免安装皮肤插件使用指南:个性化音乐播放体验 开源电子设计自动化利器:KiCad EDA全方位使用指南 Jetson TX2开发板官方资源完全指南:从入门到精通 昆仑通态MCGS与台达VFD-M变频器通讯程序详解:工业自动化控制完美解决方案 基恩士LJ-X8000A开发版SDK样本程序全面指南 - 工业激光轮廓仪开发利器 PhysioNet医学研究数据库:临床数据分析与生物信号处理的权威资源指南 QT连接阿里云MySQL数据库完整指南:从环境配置到问题解决 Python案例资源下载 - 从入门到精通的完整项目代码合集 2022美赛A题优秀论文深度解析:自行车功率分配建模的成功方法 TJSONObject完整解析教程:Delphi开发者必备的JSON处理指南
项目优选
收起
deepin linux kernel
C
24
9
Ascend Extension for PyTorch
Python
223
245
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
暂无简介
Dart
672
157
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
662
312
React Native鸿蒙化仓库
JavaScript
262
322
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
64
19
仓颉编译器源码及 cjdb 调试工具。
C++
134
867
仓颉编程语言测试用例。
Cangjie
37
860
openGauss kernel ~ openGauss is an open source relational database management system
C++
160
218