postgreSQL_jsonb中某一個鍵值對的修改操作


首先postgreSQL提供json和jsonb可以存儲json數據,這里使用的是jsonb。相對於json來說,存儲慢,使用快。

首先創建一個表,假設有三個字段,id、table_id(關聯id)、detail(json數據),這里使用的是jsonb_set函數

select * from db_table where table_id = '874b7f7793674626b2f7c23600e79519'

UPDATE db_table AS dt SET detail = jsonb_set 
(( SELECT detail FROM db_table WHERE ID = dt.ID ) :: jsonb
, '{name}', '"視頻監控"' :: jsonb, false ) :: jsonb WHERE table_id = '874b7f7793674626b2f7c23600e79519'

先介紹下jsonb_set函數

jsonb_set(target jsonb, path text[], new_value jsonb[,create_missing boolean])
target : 這是目的json數據,這里使用內部關聯將對應的json查詢出來
path : json數據對應的key值
new_value : json數據替換的value值
create_missing : true - 如果不存在對應的key值,則新增,反之,false - 不做其他操作,這里可有可無

然后就是將其sql整理到mapper.xml中,

UPDATE db_table AS dt SET detail = jsonb_set 
(( SELECT detail FROM db_table WHERE ID = dt.ID ) :: jsonb
, ${jsonb_name}, #{upd_value} :: jsonb, #{cre_value}) :: jsonb WHERE table_id = #{table_id}

這里jsonb_name 和其他的有些差別,使用是$,不防注入的,dao層傳遞的值直接進行替換

例子:

Map<String,Object> params = new HashMap<String,Object>();
params.put("jsonb_name","'{name}'"); //這里這樣寫是應該是不合理的,有時間再看看
params.put("upd_value","\""+dbTable.getName()+"\"");
params.put("cre_value", Boolean.FALSE);
params.put("dev_manage_id",dbTable.getId());

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM