欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PostgreSQL使用jsonb進行數(shù)組增刪改查的操作詳解

 更新時間:2024年03月15日 11:29:18   作者:weihubeats  
有時候我們需要使用PostgreSQL這種結(jié)構(gòu)化數(shù)據(jù)庫來存儲一些非結(jié)構(gòu)化數(shù)據(jù),PostgreSQL恰好又提供了json這種數(shù)據(jù)類型,這里我們來簡單介紹使用jsonb的一些常見操作,需要的朋友可以參考下

PostgreSQL 提供了 json和 jsonb兩種 json類型,兩者的主要區(qū)別就是,json查詢相對慢一些,插入會快一點,而jsonb則相反,查詢效率會高一點,插入會慢一點。

下面進入我們今天的正題

表結(jié)構(gòu)

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

數(shù)據(jù)也是非常簡單

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

重點是tag

[{
	"uid": 1,
	"name": "標(biāo)簽名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "標(biāo)簽名2",
	"add_time": "2021-05-29 17:00:00"
}]

操作

這里來實現(xiàn)一些簡單的操作

條件查詢

我們查詢 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' ;

查詢結(jié)果

如果僅僅是查詢json中包含 uid = 3的結(jié)果可以像這樣查詢

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

新增

新增也比較簡單,我們在原有的json上在增加個對象。
原先的json對象是這樣的

[{
	"uid": 1,
	"name": "標(biāo)簽名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "標(biāo)簽名2",
	"add_time": "2021-05-29 17:00:00"
}]

執(zhí)行如下語句

UPDATE purchase_order SET tag = tag || '[{
	"uid": 3,
	"name": "標(biāo)簽名3",
	"add_time": "2021-05-29 17:00:00"
}]' where  id = 4787;

再查詢

[{
	"uid": 1,
	"name": "標(biāo)簽名1",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 2,
	"name": "標(biāo)簽名2",
	"add_time": "2021-05-29 17:00:00"
}, {
	"uid": 3,
	"name": "標(biāo)簽名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;

再次查詢

修改

我們現(xiàn)在要把 id = 4787name = '標(biāo)簽名1'的修改為name = '標(biāo)簽new'

sql 如下

UPDATE purchase_order AS g
   SET tag = REPLACE(tag::text, '"name": "標(biāo)簽名1"','"name": "標(biāo)簽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' )

總結(jié)

其實還有很多其他方式去實現(xiàn),但是總體來說修改刪除都不是特別方便和好維護,建議修改刪除的時候直接當(dāng)做字符串去全量更新即可,這樣好維護一點。

另外附帶一份官方的 jsonb 操作文檔連接給大家自己去查閱吧

PostgreSQL: Documentation: 9.6: JSON Functions and Operators

注意文檔選擇合適的版本哦

以上就是PostgreSQL使用jsonb進行數(shù)組增刪改查的操作詳解的詳細(xì)內(nèi)容,更多關(guān)于PostgreSQL jsonb增刪改查的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論