PostgreSQL使用jsonb进行数组增删改查的操作详解

 更新时间:2024年03月15日 11:29:18   作者:weihubeats  
有时候我们需要使用PostgreSQL这种结构化数据库来存储一些非结构化数据,PostgreSQL恰好又提供了json这种数据类型,这里我们来简单介绍使用jsonb的一些常见操作,需要的朋友可以参考下

PostgreSQL 提供了 json和 jsonb两种 json类型,两者的主要区别就是,json查询相对慢一些,插入会快一点,而jsonb则相反,查询效率会高一点,插入会慢一点。

下面进入我们今天的正题

表结构

create table purchase_order
(
    id                     serial not null primary key,
    tag                    jsonb
)

数据也是非常简单

INSERT INTO purchase_order (id, tag) VALUES (4787, '[{"uid": 1, "name": "标签名1", "add_time": "2021-05-29 17:00:00"}, {"uid": 2, "name": "标签名2", "add_time": "2021-05-29 17:00:00"}]');

重点是tag

[{
	"uid": 1,
	"name": "标签名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "标签名2",
	"add_time": "2021-05-29 17:00:00"
}]

操作

这里来实现一些简单的操作

条件查询

我们查询 id = 4787 且 json 中 uid = 1 的tag

-- 嵌套子查询
select * from (
select jsonb_array_elements(tag) as tt from purchase_order where id =  4787) a
where  tt -> 'uid' = '1';

-- 或者这种方式
SELECT
    id,r
FROM
    purchase_order s, jsonb_array_elements(s.tag) r
WHERE
    s.id =  4787  and r->>'uid' = '2' ;

查询结果

如果仅仅是查询json中包含 uid = 3的结果可以像这样查询

SELECT tag FROM purchase_order
WHERE id =  4787 and tag @> '[{"uid": 3}]';

新增

新增也比较简单,我们在原有的json上在增加个对象。
原先的json对象是这样的

[{
	"uid": 1,
	"name": "标签名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "标签名2",
	"add_time": "2021-05-29 17:00:00"
}]

执行如下语句

UPDATE purchase_order SET tag = tag || '[{
	"uid": 3,
	"name": "标签名3",
	"add_time": "2021-05-29 17:00:00"
}]' where  id = 4787;

再查询

[{
	"uid": 1,
	"name": "标签名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "标签名2",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 3,
	"name": "标签名3",
	"add_time": "2021-05-29 17:00:00"
}]

删除

如果我要删除上面 uid 为3的值,使用如下sql即可

UPDATE purchase_order
       SET tag = t.js_new
      FROM
          (
           SELECT jsonb_agg( (tag ->> ( idx-1 )::int)::jsonb ) AS js_new
             FROM purchase_order
            CROSS JOIN jsonb_array_elements(tag)
             WITH ORDINALITY arr(j,idx)
            WHERE j->>'uid' NOT IN ('3')
          ) t;

再次查询

修改

我们现在要把 id = 4787name = '标签名1'的修改为name = '标签new'

sql 如下

UPDATE purchase_order AS g
   SET tag = REPLACE(tag::text, '"name": "标签名1"','"name": "标签new"')::json
 WHERE g.tag IN ( SELECT g.tag
                     FROM purchase_order AS g
                    CROSS JOIN jsonb_array_elements(g.tag) AS j
                    WHERE id = 4787 and  j ->>'uid' = '1' )

总结

其实还有很多其他方式去实现,但是总体来说修改删除都不是特别方便和好维护,建议修改删除的时候直接当做字符串去全量更新即可,这样好维护一点。

另外附带一份官方的 jsonb 操作文档连接给大家自己去查阅吧

PostgreSQL: Documentation: 9.6: JSON Functions and Operators

注意文档选择合适的版本哦

以上就是PostgreSQL使用jsonb进行数组增删改查的操作详解的详细内容,更多关于PostgreSQL jsonb增删改查的资料请关注脚本之家其它相关文章!

相关文章

  • postgresql如何找到表中重复数据的行并删除

    postgresql如何找到表中重复数据的行并删除

    这篇文章主要介绍了postgresql如何找到表中重复数据的行并删除问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • postgresql表死锁问题的排查方式

    postgresql表死锁问题的排查方式

    这篇文章主要介绍了postgresql表死锁问题的排查方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL 安装和简单使用

    PostgreSQL 安装和简单使用

    ostgreSQL是现在比较流行的数据库之一,这个起源于伯克利(BSD)的数据库研究计划目前已经衍生成一项国际开发项目,并且有非常广泛的用户。
    2009-08-08
  • 详解如何定位postgreSQL数据库中未被使用过的索引

    详解如何定位postgreSQL数据库中未被使用过的索引

    在生产环境上,由于不规范的优化措施,数据库中可能存在大量的索引,并且相当一部分的索引重未被使用过,今天带大家如何找出这些索引,本文给大家介绍了定位postgreSQL数据库中未被使用过的索引的方法,需要的朋友可以参考下
    2024-03-03
  • PostgreSQL中的外键与主键操作示例

    PostgreSQL中的外键与主键操作示例

    在PostgreSQL中,外键(Foreign Key)是一种用于建立表间关联的数据库约束机制,其核心作用与主键(Primary Key)有显著区别,本文给大家介绍PostgreSQL中的外键与主键操作示例,感兴趣的朋友一起看看吧
    2025-10-10
  • PostgreSQL 重复数据处理的操作方法

    PostgreSQL 重复数据处理的操作方法

    这篇文章主要介绍了PostgreSQL 重复数据处理的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 使用navicat连接postgresql报错问题图文解决办法

    使用navicat连接postgresql报错问题图文解决办法

    我们在日常开发中有时候需要用navicate连接postgresql数据库,有时候会连接不上数据库,下面这篇文章主要给大家介绍了关于使用navicat连接postgresql报错问题图文解决办法,需要的朋友可以参考下
    2023-11-11
  • PostgreSQL限制访问登录地址详细图文教程

    PostgreSQL限制访问登录地址详细图文教程

    限制IP访问可以显著提高数据库的安全性,防止恶意攻击和数据泄露,下面这篇文章主要介绍了PostgreSQL限制访问登录地址的相关资料,文中通过图文及代码介绍的非常详细,需要的朋友可以参考下
    2025-08-08
  • 常用 PostgreSQL 预防数据丢失解决方案

    常用 PostgreSQL 预防数据丢失解决方案

    这篇文章主要介绍了常用 PostgreSQL 预防数据丢失方案,本篇主要介绍关于 DDL 和 DML 操作,如何预防数据丢失的方案,需要的朋友可以参考下
    2022-01-01
  • Postgresql中json和jsonb类型区别解析

    Postgresql中json和jsonb类型区别解析

    在我们的业务开发中,可能会因为特殊【历史,偷懒,防止表连接】经常会有JSON或者JSONArray类的数据存储到某列中,这个时候再PG数据库中有两种数据格式可以直接一对多或者一对一的映射对象,接下来通过本文介绍Postgresql中json和jsonb类型区别,需要的朋友可以参考下
    2024-06-06

最新评论