• 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());
  • 相关阅读:
    星战代码小电影
    CDlinux 安装
    网络正常使用,图标状态显示不正常
    查询正在执行的SQL语句DBCCINPUTBUFFER
    如何在MYSQL下所有指定数据库名下执行SQL
    GHOST完成后出现GRUB解决方法
    MySql Cast与Convert函数
    MYSQL查询数据库表索引的硬盘空间占用
    警惕企业中的五种虚假执行力
    开启笔记本win7的虚拟热点笔记本变成wifi
  • 原文地址:https://www.cnblogs.com/kongkongFabian/p/10553149.html
Copyright © 2020-2023  润新知