PostgreSQL判断字符串是否是json格式

PostgreSQL判断字符串是否是json格式

在PostgreSQL中如果你的字段类型是文本类型并不是json,jsonb类型的时候,这种情况下你要判断字段是否是json格式,可以创建函数is_json来进行判断(直接文本转换json可能会报异常导致sql语句失败):

sql 复制代码
CREATE OR REPLACE FUNCTION is_json(text_to_check text)
RETURNS boolean AS $$
DECLARE
    valid_json json;
BEGIN
    -- 尝试将文本转换为 JSON 类型
    valid_json := text_to_check::json;
    -- 如果没有抛出异常,则返回 TRUE
    RETURN TRUE;
EXCEPTION
    WHEN OTHERS THEN
        -- 如果抛出异常,则返回 FALSE
        RETURN FALSE;
END;
$$ LANGUAGE plpgsql;

在这个函数中,我声明了一个名为 valid_json 的 json 类型变量,并尝试将 text_to_check 转换为 json 类型并赋值给这个变量。如果字符串是有效的 JSON,则赋值成功,函数返回 TRUE。如果字符串不是有效的 JSON,则类型转换会抛出一个异常,我们在 EXCEPTION 块中捕获这个异常并返回 FALSE。

注意,我使用了 DECLARE 语句来声明变量 valid_json,并且在 BEGIN ... END 块中执行了赋值操作。这样,我们就避免了直接在 BEGIN ... END 块中使用类型转换操作符导致的语法错误。

然后你可以使用这个函数来检查一个字符串是否是 JSON 格式:

sql 复制代码
SELECT is_json('{"key": "value"}');  -- 返回 TRUE
SELECT is_json('not a json string');  -- 返回 FALSE
相关推荐
AC赳赳老秦4 分钟前
OpenClaw与思维导图工具联动:自动生成工作规划脑图、拆解任务节点,适配职场管理
java·大数据·服务器·数据库·python·php·openclaw
zhishijike24 分钟前
全国行政区划sql(省市区)
数据库·sql·mysql
KaMeidebaby34 分钟前
卡梅德生物技术快报|单 B 细胞抗体技术:全犬源单抗制备流程、关键参数与性能验证
前端·数据库·其他·百度·新浪微博
KG_LLM图谱增强大模型38 分钟前
scHilda:大模型与知识图谱分层融合,突破单细胞分型瓶颈
数据库·人工智能·知识图谱
凯瑟琳.奥古斯特40 分钟前
力扣3654:二维矩阵连续空位统计
数据结构·数据库·算法·职场和发展
满昕欢喜1 小时前
SQL Server的概述与安装
数据库·sqlserver
howard20051 小时前
4.4 Spark SQL数据源 - JSON
json·spark sql数据源
2501_930707781 小时前
使用C#代码在 Excel 中为数据透视表添加筛选器
数据库·数据挖掘·数据分析
TDengine (老段)1 小时前
TDengine 数据库创建与参数详解
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
IT策士1 小时前
Django 从 0 到 1 打造完整电商平台:电商项目需求分析与数据库设计
数据库·django·需求分析