PG数据库的Jsonb全文检索查询

1.操作键值对

PostgreSQL 对 jsonb 类型的筛选查询可以使用 -> 或者 ->> 操作符。

  • -> 操作符用于通过 JSON 对象中的键来获取对应的值。
  • ->> 操作符可以将获取到的值提取出来转化为字符串类型。

例如,下面是一个包含 jsonb 类型字段的表:

复制代码
CREATE TABLE test (
  id SERIAL PRIMARY KEY,
  data JSONB
);
 
INSERT INTO test (data) VALUES ('{"name": "John", "age": 30, "city": "New York"}');
INSERT INTO test (data) VALUES ('{"name": "Jane", "age": 25, "city": "Los Angeles"}');

我们可以通过下面这中查询方式进行全库的全文检索查询

复制代码
-- 获取所有数据
SELECT * FROM test;
 
-- 根据 jsonb 字段中的键值进行查询
SELECT * FROM test WHERE data -> 'name' = '"John"';
-- 注意:键名需要用单引号括起来,并且值需要用双引号括起来。
 
-- 使用 ->> 将键对应的值提取出来进行查询
SELECT * FROM test WHERE data ->> 'age' = '30';

上面这个提取出来的例子可能不明显

下面添加一个复杂的json例子

复制代码
{
    "caseInfo": {
        "caseNo": "C20xxxxxxxxx8212566",
        "reportNo": "P2xxxxxxxxxxxxxxxxx3004",
        "applyTime": 17xxxxxxxxx5000,
        "companyId": 1xx00,
        "treatType": "1",
        "createFrom": 1xxx1,
        "companyName": "中国xxxxxxxxxxx公司",
        "processType": "2xx",
        "accidentDate": 171xxxxxxxx1000,
        "accidentType": "xx1x",
        "hospitalCode": "xxxxxxxxx35",
        "hospitalName": "台xxxxxxxxxxxx院",
        "hospitalLevel": "",
        "medicalFinish": "",
        "firstCompanyId": 0987654,
        "injuredFromArea": "ytgrefds",
        "insuranceTypeId": "",
        "firstCompanyName": "中xxxxxxxxxxxx限公司",
        "hospitalAttribute": "",
        "uploadUserOrgCode": "",
        "totalSettlementAmount": 0
    },
    "patientInfo": {
        "name": "邱76y5t432",
        "idCard": "33sacdvfgbdcs1232675",
        "address": "asadfghfdsa村",
        "birthday": sadcsxazxsc000,
        "cardType": "asdsad",
        "idDueDay": 2asxcv bgdfsc000,
        "genderCode": "1"
    },
    "applyUserInfo": {
        "nationality": "CHN",
        "applyUserName": "",
        "applyUserIdCard": "",
        "applyUserBirthday": "",
        "applyUserCardType": "",
        "applyUserIdDueDay": "",
        "applyUserGenderCode": "",
        "applyUserPatientRelation": ""
    }
}

这个时候提取的作用就显得明显了很多

复制代码
--  ->> 提取测试sql,将applyUserInfo下的nationality提取出来,做一维sql标准查询
SELECT count(*)
FROM case_service.cs_case_model
WHERE (cs_case_model.case_model_detail -> 'applyUserInfo' ->> 'nationality') like '%C%';

结果:

相关推荐
派可数据BI可视化10 分钟前
商业智能BI 浅谈数据孤岛和数据分析的发展
大数据·数据库·数据仓库·信息可视化·数据挖掘·数据分析
yong999012 分钟前
C#驱动斑马打印机实现包装自动打印
java·数据库·c#
IvorySQL23 分钟前
在一台机器上搭建一体化 Ceph 存储集群
postgresql·开源
野犬寒鸦43 分钟前
从零起步学习MySQL || 第五章:select语句的执行过程是怎么样的?(结合源码深度解析)
java·服务器·数据库·后端·mysql·adb
QT 小鲜肉1 小时前
【个人成长笔记】Qt 中 SkipEmptyParts 编译错误解决方案及版本兼容性指南
数据库·c++·笔记·qt·学习·学习方法
我是苏苏1 小时前
C#高级:数据库中使用SQL作分组处理4(LAG() 偏移函数)
数据库
wudl55662 小时前
股票300394(天孚通信)2025年4月20日
数据库
IvorySQL2 小时前
PostgreSQL 18 中国贡献者经验分享:开源参与的四点建议
数据库·postgresql·开源
曾凡宇先生2 小时前
openEuler安装jdk,nginx,redis
linux·开发语言·数据库·openeuler
点灯小铭2 小时前
基于单片机的四沟道步进电机玉米补种机设计与实现
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业