PostgreSQL使用jsonb進行數(shù)組增刪改查的操作詳解
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 = 4787
name = '標(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)文章
PostgreSQL 查看表的主外鍵等約束關(guān)系詳解
這篇文章主要介紹了PostgreSQL 查看表的主外鍵等約束關(guān)系詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01Postgresql 存儲過程(plpgsql)兩層for循環(huán)的操作
這篇文章主要介紹了Postgresql 存儲過程(plpgsql)兩層for循環(huán)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSql 導(dǎo)入導(dǎo)出sql文件格式的表數(shù)據(jù)實例
這篇文章主要介紹了PostgreSql 導(dǎo)入導(dǎo)出sql文件格式的表數(shù)據(jù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01Postgresql 數(shù)據(jù)庫轉(zhuǎn)義字符操作
這篇文章主要介紹了Postgresql 數(shù)據(jù)庫轉(zhuǎn)義字符操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01自定義函數(shù)實現(xiàn)單詞排序并運用于PostgreSQL(實現(xiàn)代碼)
這篇文章主要介紹了自定義函數(shù)實現(xiàn)單詞排序并運用于PostgreSQL,本文給大家分享實現(xiàn)代碼,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04CentOS 7下安裝PostgreSQL 9.6的教程分享
PostgreSQL在我心目中的地位要遠(yuǎn)遠(yuǎn)高于MySQL,雖然流行對比MySQL低很對,但是功能性一致走在MySQL的前面。下面這篇文章主要介紹了CentOS 7下安裝PostgreSQL數(shù)據(jù)庫的方法,需要的朋友可以參考借鑒,一起來看看吧。2017-02-02PostgreSQL 數(shù)據(jù)庫跨版本升級常用方案解析
這篇文章主要介紹了PostgreSQL 數(shù)據(jù)庫跨版本升級常用方案解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03PostgreSQL數(shù)據(jù)庫命令行執(zhí)行SQL腳本的三種方式
生成環(huán)境中,出于安全性等原因,往往不提供數(shù)據(jù)庫連接工具,所以對數(shù)據(jù)庫的更新和升級就得通過命令行來實現(xiàn),本文總結(jié)了三種命令行執(zhí)行sql腳本的方式,需要的朋友可以參考下2024-02-02