PostgreSQL使用jsonb進(jìn)行數(shù)組增刪改查的操作詳解
PostgreSQL 提供了 json和 jsonb兩種 json類型,兩者的主要區(qū)別就是,json查詢相對(duì)慢一些,插入會(huì)快一點(diǎn),而jsonb則相反,查詢效率會(huì)高一點(diǎn),插入會(huì)慢一點(diǎn)。
下面進(jìn)入我們今天的正題
表結(jié)構(gòu)
create table purchase_order
(
id serial not null primary key,
tag jsonb
)
數(shù)據(jù)也是非常簡(jiǎn)單
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"}]');
重點(diǎn)是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"
}]
操作
這里來(lái)實(shí)現(xiàn)一些簡(jiǎ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}]';
新增
新增也比較簡(jiǎn)單,我們?cè)谠械膉son上在增加個(gè)對(duì)象。
原先的json對(duì)象是這樣的
[{
"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í)行如下語(yǔ)句
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"
}]
刪除
如果我要?jiǎng)h除上面 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é)
其實(shí)還有很多其他方式去實(shí)現(xiàn),但是總體來(lái)說(shuō)修改刪除都不是特別方便和好維護(hù),建議修改刪除的時(shí)候直接當(dāng)做字符串去全量更新即可,這樣好維護(hù)一點(diǎn)。
另外附帶一份官方的 jsonb 操作文檔連接給大家自己去查閱吧
PostgreSQL: Documentation: 9.6: JSON Functions and Operators
注意文檔選擇合適的版本哦
以上就是PostgreSQL使用jsonb進(jìn)行數(shù)組增刪改查的操作詳解的詳細(xì)內(nèi)容,更多關(guān)于PostgreSQL jsonb增刪改查的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
PostgreSQL 查看表的主外鍵等約束關(guān)系詳解
這篇文章主要介紹了PostgreSQL 查看表的主外鍵等約束關(guān)系詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
Postgresql 存儲(chǔ)過(guò)程(plpgsql)兩層for循環(huán)的操作
這篇文章主要介紹了Postgresql 存儲(chǔ)過(guò)程(plpgsql)兩層for循環(huán)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
PostgreSql 導(dǎo)入導(dǎo)出sql文件格式的表數(shù)據(jù)實(shí)例
這篇文章主要介紹了PostgreSql 導(dǎo)入導(dǎo)出sql文件格式的表數(shù)據(jù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
Postgresql 數(shù)據(jù)庫(kù)轉(zhuǎn)義字符操作
這篇文章主要介紹了Postgresql 數(shù)據(jù)庫(kù)轉(zhuǎn)義字符操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
自定義函數(shù)實(shí)現(xiàn)單詞排序并運(yùn)用于PostgreSQL(實(shí)現(xiàn)代碼)
這篇文章主要介紹了自定義函數(shù)實(shí)現(xiàn)單詞排序并運(yùn)用于PostgreSQL,本文給大家分享實(shí)現(xiàn)代碼,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
CentOS 7下安裝PostgreSQL 9.6的教程分享
PostgreSQL在我心目中的地位要遠(yuǎn)遠(yuǎn)高于MySQL,雖然流行對(duì)比MySQL低很對(duì),但是功能性一致走在MySQL的前面。下面這篇文章主要介紹了CentOS 7下安裝PostgreSQL數(shù)據(jù)庫(kù)的方法,需要的朋友可以參考借鑒,一起來(lái)看看吧。2017-02-02
PostgreSQL 數(shù)據(jù)庫(kù)跨版本升級(jí)常用方案解析
這篇文章主要介紹了PostgreSQL 數(shù)據(jù)庫(kù)跨版本升級(jí)常用方案解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
PostgreSQL數(shù)據(jù)庫(kù)命令行執(zhí)行SQL腳本的三種方式
生成環(huán)境中,出于安全性等原因,往往不提供數(shù)據(jù)庫(kù)連接工具,所以對(duì)數(shù)據(jù)庫(kù)的更新和升級(jí)就得通過(guò)命令行來(lái)實(shí)現(xiàn),本文總結(jié)了三種命令行執(zhí)行sql腳本的方式,需要的朋友可以參考下2024-02-02

