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' 返回 成功!(纯文本),适合直接比较。

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

相关推荐
小尧嵌入式3 分钟前
Linux的shell命令
linux·运维·服务器·数据库·c++·windows·算法
voltina3 分钟前
事务操作流程
数据库
antzou18 分钟前
嵌入式数据库管理
数据库·办公软件·h2·效率工具
嫂子的姐夫21 分钟前
py连接Redis
数据库·redis·爬虫·去重
Fortune_yangyang23 分钟前
ELK 监控MySQL日志
数据库·mysql·elk
长而不宰29 分钟前
使用 Canal实时监听数据库变化
java·数据库·spring boot
gc_229931 分钟前
Ape.Volo项目源码学习(2:数据库结构)
数据库·ape.volo
历程里程碑34 分钟前
C++ 8:list容器详解与实战指南
c语言·开发语言·数据库·c++·windows·笔记·list
CodeAmaz1 小时前
mysql乐观锁和悲观锁
数据库·mysql·乐观锁·悲观锁
MasonYyp1 小时前
简单使用FalkorDB和Neo4j图数据库
数据库·neo4j