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());

 

转载于:https://www.cnblogs.com/kongkongFabian/p/10553149.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值