解决人大金仓数据库KingbaseES json_equal表达式不支持json和jsonb类型的问题

关键字

JSON_EQUAL、参数类型、JSON、JSONB、人大金仓

问题描述

对于目前KES中oracle模式下JSON_EQUAL比较输入的两个JSON值是否相等这一条件表达式,当为表达式中参数1与参数2的任意位置传入json或jsonb值时,KES均不能有效支持该种类型参数的传入,导致报错。详见下图,当对表达式中传入的数据转换为json或者是jsonb以及原生json值时,会出现报错提示,该报错出现的原因即为不支持上述类型。

问题分析

缺少JSON和JSONB参数类型的支持

解决方案

为了更好地支持用户的行为,提升KES的可使用性,并能够兼容Oracle数据库,在支持JSON_EQUAL表达式的基础之上添加了表达式支持json和jsonb两种参数类型。其中,表达式的两个参数位置均可支持json和jsonb两种参数,具体使用案例如下所示:

两个输入均为json与jsonb类型:

select json_equal('{"uzi":1}'::json,'{"uzi":2}'::jsonb error on error);

select json_equal('{"uzi":1}'::json,'{"uzi":2}'::json);

select json_equal(jsonb'{"uzi":1}',jsonb'{"uzi":1}');

select json_equal(jsonb'{"uzi":1}',json'{"uzi":1}' error on error);

select json_equal('1'::json,'1'::json);

select json_equal('{"uzi":1}'::varchar::jsonb,'{"uzi":2}'::varchar::jsonb);

select json_equal(lower('{"A":1}')::jsonb,'{"a":2}'::jsonb);

select json_equal('[1,2]'::json,'[1,2]'::json);

其中一个为json或jsonb类型

select json_equal('1','{"a":[1,2]}'::json);

select json_equal('false','{"a":[1,2]}'::json);

select json_equal('{"a":[1,2]}'::json,null);

select json_equal('1'::json,'1');

参考资料

《KingbaseES SQL语言参考手册》

相关推荐
TDengine (老段)4 分钟前
TDengine 转换函数 TO_JSON 用户手册
android·大数据·数据库·json·时序数据库·tdengine·涛思数据
2301_8002561112 分钟前
第七章 空间存储与索引 知识点梳理3(空间填充曲线)
数据库·笔记·sql·postgresql
冰封剑心17 分钟前
MiniCPM-V-2_6 (4-bit 量化)使用
java·前端·数据库
小满、1 小时前
MySQL :存储引擎原理、索引结构与执行计划
数据库·mysql·索引·mysql 存储引擎
x***13391 小时前
SQL Server 创建用户并授权
数据库·oracle
JIngJaneIL1 小时前
智慧物业|物业管理|基于SprinBoot+vue的智慧物业管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·论文·智慧物业管理系统
枫叶梨花1 小时前
一次 Kettle 中文乱码写入失败的完整排查实录
数据库·后端
笃行客从不躺平2 小时前
遇到大SQL怎么处理
java·开发语言·数据库·sql
逻极3 小时前
Redis Queue (RQ) 核心原理:轻量任务队列的设计与实践(一句话讲透核心本质)
数据库·redis·bootstrap
q***31833 小时前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存