Apache Arrow DataFusion 中 Parquet 数据剪枝对更多类型的支持
在 Apache Arrow DataFusion 项目中,Parquet 文件格式的数据剪枝(pruning)功能是一个重要的性能优化手段。它通过利用 Parquet 文件中的列统计信息(如最小值、最大值等)来跳过不相关的数据页或行组,从而减少 I/O 操作和提高查询性能。
目前 DataFusion 的剪枝功能主要支持整数类型等有限的数据类型,而对于浮点类型的支持存在一些限制。当用户使用浮点列进行过滤查询时,如果查询条件中包含浮点字面量(如 10.0),系统会自动将其视为双精度浮点数(Float64),这会导致浮点列被强制转换为双精度类型,从而无法利用现有的统计信息进行剪枝优化。
这个问题源于 DataFusion 物理优化器中的 verify_support_type_for_prune 函数,该函数目前只允许特定类型的转换组合。具体来说,当遇到浮点列与双精度字面量的比较时,系统会阻止使用统计信息进行剪枝。
解决方案可以从两个角度考虑:
-
扩展
verify_support_type_for_prune函数,使其支持更多数值类型之间的转换,特别是浮点类型。一个简单的改进是将检查条件放宽为"如果源类型和目标类型都是数值类型"。 -
在查询解析阶段,对浮点字面量进行更智能的类型推断,避免不必要的类型提升。例如,当浮点列与 10.0 比较时,可以尝试将字面量保持为单精度浮点数(Float32)而非默认的双精度。
值得注意的是,浮点数的剪枝还涉及到一些特殊值的处理,如 NaN(非数字)。根据 Parquet 格式规范,NaN 值的比较行为需要特别处理,这增加了实现的复杂性。在实际查询中,如果统计信息中包含 NaN 值,剪枝逻辑需要确保不会错误地排除有效数据。
这个优化对于数据分析工作负载尤为重要,因为许多科学计算和机器学习应用都广泛使用浮点数据类型。通过完善浮点类型的剪枝支持,可以显著提升这类查询的性能,特别是在处理大型 Parquet 数据集时。
随着 Apache Arrow 生态系统的不断发展,对 Parquet 格式的支持也在持续完善。这个问题的解决不仅会提升 DataFusion 的性能,也将增强其与其他大数据处理工具的互操作性。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112