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 小时前
python学习基础
开发语言·数据库·python
让学习成为一种生活方式4 小时前
Pfam 数据库详解--生信工具60
数据库
q***49864 小时前
数据库操作与数据管理——Rust 与 SQLite 的集成
数据库·rust·sqlite
川西胖墩墩5 小时前
流程图在算法设计中的实战应用
数据库·论文阅读·人工智能·职场和发展·流程图
clownAdam6 小时前
MongoDB-cdc原理
数据库·mongodb
玄妙之门6 小时前
项目实战中redis和数据库结合提升缓存效率
数据库·redis·缓存
q***4647 小时前
maven导入spring框架
数据库·spring·maven
得物技术7 小时前
一文解析得物自建 Redis 最新技术演进
数据库·redis·云计算
沐浴露z7 小时前
一张思维导图理清 【MySQL】
数据库·mysql
7澄18 小时前
MySQL 数据库进阶:SQL 查询语句全解析
数据库·mysql·查询·模糊查询·条件查询·聚合函数·基础查询