chdb项目中JSON_VALUE函数无法使用的编译问题解析
2025-07-02 02:41:33作者:戚魁泉Nursing
在chdb项目中,用户报告了一个关于JSON_VALUE函数无法正常使用的问题。该问题表现为当用户尝试执行包含JSON_VALUE函数的SQL查询时,系统会抛出"Functions JSON* are not supported"的错误提示。
经过技术分析,这个问题实际上是由于macOS平台下的编译配置问题导致的。在chdb项目的build.sh构建脚本中,缺少了必要的编译标志,导致JSON相关功能没有被正确编译进最终的可执行文件中。
JSON_VALUE函数是ClickHouse提供的一个用于从JSON格式字符串中提取特定值的函数。它遵循标准的JSONPath语法,能够方便地从复杂的JSON结构中提取所需数据。在正常情况下,该函数应该能够解析简单的JSON对象并返回指定路径下的值。
对于开发者而言,这类编译时功能缺失问题通常需要检查以下几个方面:
- 构建脚本中是否包含了所有必要的依赖项
- 平台特定的编译标志是否配置正确
- 目标功能是否被错误地排除在编译选项之外
该问题已经在chdb项目的271号提交中得到修复。修复方案主要是调整了build.sh脚本中的编译配置,确保JSON相关功能能够被正确编译和包含。这种类型的修复对于保证跨平台兼容性非常重要,特别是在处理不同操作系统环境下的构建问题时。
对于使用chdb的用户来说,遇到类似功能不可用的情况时,可以考虑以下解决步骤:
- 确认使用的chdb版本是否包含最新修复
- 检查运行环境是否满足所有依赖要求
- 在社区或issue跟踪系统中搜索是否有相关问题的讨论
这个案例也提醒我们,在使用开源数据库项目时,理解其底层依赖和构建过程对于问题诊断非常重要。特别是在跨平台使用时,不同操作系统的特性可能会导致某些功能出现兼容性问题。
登录后查看全文
热门项目推荐
相关项目推荐
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 StartedRust0171
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook092
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
BitCPM-CANN-8BBitCPM-CANN 是首个基于华为昇腾 NPU 原生构建的端到端 1.58 位(三值化)大语言模型训练系统。该系统将量化感知训练(QAT)集成到 Megatron-LM 框架中,并结合 MindSpeed 加速,覆盖了从自定义三值算子到基于昇腾 910B 的分布式并行训练的完整训练栈。Python00
MiniCPM5-1BMiniCPM5-1B,这是 MiniCPM5 系列的首款模型。它是一个专为端侧、本地部署和资源受限场景打造的 10 亿参数密集型 Transformer 模型,达到了 10 亿参数级开源模型的 SOTA 水平Jinja00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0239
项目优选
收起
暂无描述
Dockerfile
748
4.86 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
641
1.26 K
Ascend Extension for PyTorch
Python
685
828
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
834
1.83 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
449
416
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.02 K
1.04 K
Claude 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 Started
Rust
1.51 K
171
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
933
554
暂无简介
Dart
995
257
昇腾LLM分布式训练框架
Python
172
211