Doris为2.1版本,但json_each不可以用解决方法

Doris 2.1 版本(原生支持json_each函数),但该函数无法使用,核心原因是FE 节点的功能开关未开启(Doris 2.x 部分 JSON 高级函数默认关闭,需手动配置启用),而非版本不兼容。

一、先排查:确认json_each函数是否可见

先执行 SQL 查看 Doris 是否加载了json_each函数,判断是配置问题还是语法问题:

sql

复制代码
-- 查看所有JSON相关函数,确认json_each是否存在
SHOW FUNCTIONS LIKE '%json_each%';
  • 若查询结果为空:说明功能未启用,需按下面步骤配置。
  • 若查询到json_each函数:说明是语法问题,直接跳至 "三、语法修正:2.1 版本 json_each 正确用法"。

二、启用json_each:配置 FE 功能开关

json_each属于 Doris 的高级 JSON 函数 ,需在 FE 节点开启enable_vectorized_engineenable_json_function配置(2.1 版本默认可能关闭),步骤如下:

步骤 1:登录 FE 节点服务器
复制代码
# 进入FE安装目录的conf文件夹(替换为你的实际路径)
cd /opt/apache-doris/fe/conf
步骤 2:修改 fe.conf 配置文件

编辑fe.conf,添加或修改以下配置项:

复制代码
# 启用向量化引擎(json_each依赖该引擎)
enable_vectorized_engine = true

# 启用高级JSON函数(显式开启json_each等功能)
enable_json_function = true

# 可选:若仍无法使用,添加该配置(兼容部分2.1版本)
enable_experimental_json_function = true
步骤 3:重启 FE 节点(使配置生效)
复制代码
# 进入FE的bin目录
cd /opt/apache-doris/fe/bin

# 停止FE(若为集群部署,先停止其他FE,最后停止leader节点)
./stop_fe.sh

# 启动FE
./start_fe.sh --daemon
步骤 4:验证配置是否生效

重启 FE 后,重新连接 Doris,执行以下 SQL:

复制代码
-- 再次查看json_each函数
SHOW FUNCTIONS LIKE '%json_each%';

-- 测试基础json_each功能
SELECT * FROM dual
LATERAL VIEW json_each('{"a":1, "b":2}') j;

若能查询到json_each函数,且测试 SQL 正常返回结果,说明功能已启用。

Doris 2.1 版本中,json_each依赖向量化引擎JSON 高级功能开关,默认可能关闭,需手动配置启用。

相关推荐
Java成神之路-20 小时前
SpringMVC 响应实战指南:页面、文本、JSON 返回全流程(Spring系列13)
java·spring·json
我命由我123451 天前
在 React 项目中,可以执行 npm start 命令,但是,无法执行 npm build 命令
前端·javascript·vue.js·react.js·前端框架·json·ecmascript
带刺的坐椅1 天前
RFC 9535:JSONPath 的标准化之路
java·json·jsonpath·snack4·rfc9535
孙同学20201 天前
如何将 JSON 数据转换为 Excel 工作表
python·json·excel
AllData公司负责人1 天前
AllData数据中台通过集成开源项目Apache IOTDB Web相关项目,建设物联网数据库平台
数据仓库·物联网·时序数据库·iotdb·工业物联网·apache iotdb·物联网数据库平台
Leo.yuan1 天前
数据仓库是什么?数据仓库和BI有什么区别?
数据仓库
ID_180079054732 天前
除了 Python,还有哪些语言可以解析 JSON 数据?
开发语言·python·json
heimeiyingwang2 天前
【架构实战】ETL架构演进:从批处理到实时流处理
数据仓库·架构·etl
电商API&Tina2 天前
跨境电商如何接入1688官方寻源通接口?附接入流程
java·数据库·python·sql·oracle·json·php
素玥2 天前
实训4 ETL构建中间层
数据仓库·etl