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
相关推荐
Leon-Ning Liu12 分钟前
Oracle 26ai新特性:时区、表空间、审计方面的新特性
数据库·oracle
humors22123 分钟前
各厂商工具包网址
java·数据库·python·华为·sdk·苹果·工具包
Yushan Bai1 小时前
ORACLE数据库在进行DROP TABLE时失败报错ORA-00604问题的分析处理
数据库·oracle
77美式1 小时前
Node + Express + MongoDB 后端部署全解析:新手零踩坑
数据库·mongodb·express
城数派1 小时前
2000-2025年我国省市县三级逐8天日间地表温度数据(Shp/Excel格式)
数据库·arcgis·信息可视化·数据分析·excel
AC赳赳老秦2 小时前
OpenClaw text-translate技能:多语言批量翻译,解决跨境工作沟通难题
大数据·运维·数据库·人工智能·python·deepseek·openclaw
AI应用实战 | RE2 小时前
014、索引高级实战:当单一向量库不够用的时候
数据库·人工智能·langchain
ffqws_2 小时前
Spring Boot入门:通过简单的注册功能串联Controller,Service,Mapper。(含有数据库建立,连接,及一些关键注解的讲解)
数据库·spring boot·后端
清水白石0082 小时前
《Python 架构师的自动化哲学:从基础语法到企业级作业调度系统与 Airflow 止损实战》
数据库·python·自动化
阿华田5122 小时前
MySQL性能优化大全
数据库·mysql·性能优化