Druid 1.2.24版本将支持ClickHouse的ARRAY JOIN语法解析
在数据库中间件Druid的最新开发进展中,1.2.24版本将增加对ClickHouse数据库ARRAY JOIN语法的完整支持。这一改进解决了长期以来Druid在解析ClickHouse特定语法时的兼容性问题。
问题背景
ClickHouse作为一款高性能的列式数据库,提供了许多特有的SQL语法扩展,其中ARRAY JOIN就是其核心功能之一。这个语法允许用户将数组类型的列展开为多行,这在数据分析场景中非常实用。
然而在Druid 1.2.8及更早版本中,当用户尝试执行包含ARRAY JOIN的ClickHouse查询时,Druid的SQL解析器会抛出"sql injection violation"错误,错误信息显示"not supported.pos 382, line 15, column 50, token IDENTIFIER ARRAY"。
技术实现分析
Druid作为Java生态中广泛使用的数据库连接池和SQL解析器,其核心功能之一就是对各种数据库方言的SQL语句进行解析和验证。在1.2.24版本之前,Druid的SQL解析器没有完整实现ClickHouse的ARRAY JOIN语法识别。
ARRAY JOIN是ClickHouse特有的语法,它可以将数组类型的列"展开"为多行。例如:
SELECT id, name, age, local FROM mr_tbl ARRAY JOIN local
这个查询会将mr_tbl表中local数组列的每个元素展开为单独的行。
解决方案
Druid开发团队在最新代码中已经完成了对ARRAY JOIN语法的解析支持。这一改进包括:
- 在SQL解析器中添加了对ARRAY JOIN关键字的识别
- 完善了ClickHouse方言的语法树构建逻辑
- 确保解析后的SQL能够正确传递给底层ClickHouse JDBC驱动执行
版本规划
这一改进将在Druid 1.2.24版本中正式发布。对于需要使用ClickHouse ARRAY JOIN功能的用户,建议等待该版本发布后升级。
实际应用示例
以一个实际的表结构为例:
CREATE TABLE mr_tbl
(
`id` UInt8,
`name` String,
`age` Int,
`local` Array(String)
)
ENGINE = MergeTree()
ORDER BY id
插入测试数据后,使用ARRAY JOIN查询将可以正常执行,而不再出现语法解析错误。
这一改进将显著提升Druid在ClickHouse生态中的兼容性,为大数据分析应用提供更好的支持。
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