postgresql中jsonb格式的数据如何进行查询过滤

postgresql中jsonb格式的数据如何进行查询过滤

背景

{"resultStatus":"success","resultCode":"100","resultMsg":"成功!","data":null}

上述是postgresql中 jsonb格式的数据,根据json中的resultMsg字段的值进行过滤的sql

根据jsonb类型字段中json中的某个属性值进行过滤

PostgreSQL jsonb字段按resultMsg过滤的SQL

若表名为 your_table,jsonb字段名为 json_data,过滤 resultMsg 为指定值的SQL如下:

1. 精确匹配(等于"成功!")
复制代码
SELECT * FROM your_table 
WHERE json_data ->> 'resultMsg' = '成功!';
  • 说明->> 操作符提取jsonb字段中 resultMsg 的文本值,然后与目标字符串比较。
2. 模糊匹配(包含"成功"关键词)
复制代码
SELECT * FROM your_table 
WHERE json_data ->> 'resultMsg' LIKE '%成功%';
3. 结合其他条件(如resultStatus为"success")
复制代码
SELECT * FROM your_table 
WHERE 
  json_data ->> 'resultStatus' = 'success' 
  AND json_data ->> 'resultMsg' = '成功!';
关键语法说明
  • -> :返回jsonb对象(保留json格式),如 json_data -> 'resultMsg' 返回 "成功!"(带引号)。
  • ->> :返回文本字符串(去除引号),如 json_data ->> 'resultMsg' 返回 成功!(纯文本),适合直接比较。

根据实际需求选择操作符,精确匹配推荐用 ->>,效率更高。

相关推荐
XDHCOM20 小时前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜20 小时前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage20 小时前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn21 小时前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜21 小时前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick199321 小时前
SQL 执行流程
数据库·sql
M--Y21 小时前
Redis常用数据类型
数据结构·数据库·redis
猿小喵21 小时前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
Y001112361 天前
MySQL-进阶
开发语言·数据库·sql·mysql
徒 花1 天前
数据库知识复习01
数据库