Postgresql 删除数组中的元素

extra为 {"a": [null, 3, null],"b": 111} 使用sql 将extra中a中的null移除

第一步:

首先先把[null, 3, null]移除,

sql 复制代码
select json_agg(elem) filter ( where elem != 'null' )
from (select jsonb_array_elements('[null,3,null]'::jsonb) as elem) t;

这将得到[3]

  1. jsonb_array_elements 会展开 extra 中 a 数组的每个元素。
  2. filter ( where elem != 'null' ) 用于过滤掉 null。
  3. 使用 jsonb_agg 将非 null 的值重新聚合为一个数组。

第二步:

使用jsonb_set更新数据

sql 复制代码
update table_name
SET extra = jsonb_set(extra::jsonb, '{a}', (select json_agg(elem)
                                            from jsonb_array_elements((extra -> 'a')::jsonb) as elem
                                            where elem != 'null')::jsonb)
where extra::jsonb ? 'a';

更多json用法:

http://www.postgres.cn/docs/12/functions-json.html

相关推荐
罗小爬EX33 分钟前
MySql批量迁移数据库
数据库·mysql
言成言成啊33 分钟前
PostgreSQL维护——解决索引膨胀和数据死行
数据库·postgresql
WZF-Sang34 分钟前
【MySQL】数据类型【mysql当中各自经典的数据类型的学习和使用】
linux·数据库·sql·学习·mysql·adb
挠背小能手34 分钟前
达梦DIsql使用方法
数据库
迷茫运维路38 分钟前
mysql5.7常用操作命令手册
运维·数据库
玖石书1 小时前
etcd 集群搭建与测试指南
数据库·etcd·集群
南叔先生1 小时前
Linux 性能优化 copy
网络·数据库·php
好记忆不如烂笔头abc1 小时前
统计信息的导出导入
数据库
Casual_Lei2 小时前
Neo4j
数据库·oracle·neo4j
IT枫斗者2 小时前
集合工具类
java·linux·数据库·windows·算法·microsoft