首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在postgresql中替换任何泛型jsonb的*text*值中的"-“?

在PostgreSQL中替换任何泛型jsonb的text值中的"-",可以使用jsonb_set函数结合jsonb_each_text函数来实现。

jsonb_each_text函数将jsonb对象转换为键值对的形式,其中键为jsonb对象的键,值为jsonb对象的值。然后可以使用jsonb_set函数来替换值中的"-"。

以下是一个示例代码:

代码语言:txt
复制
UPDATE your_table
SET your_column = jsonb_set(your_column, '{key}', to_jsonb(replace(value, '-', '')))
FROM (
    SELECT key, value
    FROM your_table, jsonb_each_text(your_column)
) AS subquery
WHERE your_table.id = subquery.id;

上述代码中,your_table是要更新的表名,your_column是包含jsonb对象的列名,keyvalue是子查询中的别名,id是用于连接子查询和主查询的列名。

这段代码将会遍历jsonb对象的每个键值对,将值中的"-"替换为空字符串,并更新到原始的jsonb对象中。

请注意,这只是一个示例代码,具体的表名、列名和条件需要根据实际情况进行修改。

关于PostgreSQL的更多信息和使用方法,可以参考腾讯云的相关产品和文档:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

java:通过自定义ParameterizedType实现参数化类型类型参数替换

需求说明 如果要动态构造一个参数对象(ParameterizedType),guava提供TypeToken工具可以部分实现这个功能: 比如下面这个例子(来自guava wiki TypeToken...TypeParameter构造一个新ParameterizedType,如果想根据一个已有的ParameterizedType对象替换其中参数,上面的方法并不能实现。...实现这个需求最关键就是要有一个ParameterizedType接口实现类,有了这个实现类,你想怎么替换都成。...别逗了,还真打算从头自己写一个啊,再说自己敢用么? 直接把jdkParameterizedTypeImpl代码抄来改改就可以啦 其实这个问题我也是琢磨了好长时间才想通。...完整代码如下(中文注释部分是我增加方法),代码中用到了guavaTypeToken工具类实现,只是为了少写些代码。

4.7K80
  • PostgreSQL JSONB 使用入门

    也有很多 JSON 相关函 数和操作符可以用于存储在这些数据类型数据 PostgreSQL支持两种 JSON 数据类型:json 和 jsonb。它们几乎接受完全相同集合作为输入。...如果一个 JSON 对象包含同一个键超过一次,所有的键/对都会被保留(** 处理函数会把最后值当作有效**)。 jsonb不保留空格、不保留对象键顺序并且不保留重复对象键。...json 输入输出语法 -- 简单标量/基本 -- 基本可以是数字、带引号字符串、true、false或者null SELECT '5'::json; -- 有零个或者更多元素数组(元素不需要为同一类...是true (缺省是true),并且path指定路径在target 不存在,那么target将包含path指定部分, new_value替换部分, 或者new_value添加部分。...(‘hello', '14:2 23:4'),表示hello在14:2和23:4这两个位置出现过,在PG这些位置实际上就是元组tid(行号,包括数据块ID(32bit),以及item point

    8K20

    MySQL与PostgreSQL对比

    LAMPM指就是MySQL。构建在LAMP上应用都会使用MySQL,WordPress、Drupal等大多数php开源程序。...text存储接送要高效很多 json和jsonb之间区别 jsonb和json在更高层面上看起来几乎是一样,但在存储实现上是不同。...json存储完文本,json列会每次都解析存储,它不支持索引,但你可以为查询创建表达式索引。 jsonb存储二进制格式,避免了重新解析数据结构。...json列会每次都解析存储,这意味着键顺序要和输入时候一样。但jsonb不同,以二进制格式存储且不保证键顺序。因此,如果你有软件需要依赖键顺序,jsonb可能不是你应用最佳选择。...使用jsonb优势还在于你可以轻易整合关系数据和非关系数据, PostgreSQL对于mongodb这类基于文档数据库是个不小威胁,毕竟如果一个表只有一列数据类型是半结构化,没有必要为了迁就它而整个表设计采用

    9K10

    Postgresql架构」使用PostgreSQLJSONB数据类型加快操作

    这有一些直接好处: 效率更高, 加工速度明显加快 支持索引(这可能是一个重要优势,我们稍后会看到), 更简单模式设计(用jsonb替换实体 - 属性 - (EAV)表,可以查询,索引和连接,从而使性能提高到...最后一个问题背后原因是,对于任何给定列,PostgreSQL保存描述性统计信息,例如不同和最常见数量,NULL条目的分数,以及 - 对于有序类型 - 数据分布直方图。...为避免这种情况,您可以考虑存储稍后可能在常规字段上汇总数据。 有关此问题进一步评论,您可以阅读Heap博客文章何时在PostgreSQL架构避免使用JSONB。...事实上,我们可以 - 并且可能应该在DB大小增加时 - 索引在过滤结果时要在WHERE子句上使用任何内容。 注意事项 切换到jsonb数据类型时,您需要考虑一些技术细节。...最后,请注意我已经涵盖了指数及其运算符一些典型用法;有关更多详细信息和示例,请查看官方PostgreSQL文档jsonb索引以及JSON函数和运算符。

    6.1K20

    PostgreSQLJSON处理:技巧与应用》

    在这篇文章里,我会为大家详细讲解《PostgreSQLJSON处理:技巧与应用》。一起来挖掘吧! 引言 随着现代应用对于数据结构多样性要求增加,JSON在PostgreSQL角色日益重要。...使用jsonb_set函数来更新 JSONB 数据: UPDATE my_table SET data = jsonb_set(data, '{path}', '"new_value"'); 4...实战:PostgreSQL JSON 应用案例 5.1 动态表单 在动态表单,数据结构经常发生变化,使用 JSON 数据类型可以灵活地存储表单字段和数据。...这些示例展示了如何在实际应用中使用 JSON 和 JSONB 数据类型来应对动态数据结构和配置需求,这些需求随着时间推移可能会发生变化。 JSON 数据类型在这些情况下提供了一种灵活解决方案。...总结 在PostgreSQL处理JSON并不复杂,但为了充分发挥其性能优势,我们需要深入了解它特性和操作技巧。希望猫头虎这篇文章能够帮助你在实际工作更好地处理JSON数据!

    38710

    JSON 与 JSONB

    现在很多开源系统和开源软件都支持 JSON 与 JSONB,比如:Postgresql 和 MongoDB 等。这也导致了面试中被问到 JSON 与 JSONB 区别时,很多人不知所措! ?...) 当jsonb将在未来稳定版发行可用时,这有两个主要使用情况,你很容易在他们之间选择: 如果你应用只用json表示,PostgreSQL只用于保存与获取时,你应该使用json....如果你需要在PostgreSQL做比较多json操作,或者在一些json字段上使用索引时,你应该使用jsonb ---- 官方文档上说: 有两个JSON数据类型:json和jsonb。...另外,如果一个JSON对象多次包含相同键,那么保存所有的键/对。(处理函数将最后一个值当做操作。)相比之下, jsonb不保存空格,也不保存对象键顺序,并且不保存重复对象键。...右操作符为text: 通过键获取json ? ->> 右操作符为int: 获取JSON数组元素为text ? 右操作符为text: 通过键获取jsontext ?

    4.9K10

    Citus 分布式 PostgreSQL 集群 - SQL Reference(创建和修改分布式表 DDL)

    例如,假设一个多租户电子商务网站需要为其任何商店交易计算销售税。税务信息并非特定于任何租户。将其合并到共享表是有意义。...如果您不关心表 co-location,请忽略此参数。它默认为 'default' ,它将表与具有相同分布列类型、分片计数和复制因子任何其他默认 co-location 表分组。...删除表 您可以使用标准 PostgreSQL DROP TABLE 命令来删除您分布式表。与常规表一样,DROP TABLE 删除目标表存在任何索引、规则、触发器和约束。...添加列或更改其默认工作方式与在单机 PostgreSQL 数据库中一样: ALTER TABLE https://www.postgresql.org/docs/current/static/ddl-alter.html...但是,不能更改分布列数据类型。此列确定表数据如何在 Citus 集群中分布,修改其数据类型将需要移动数据。

    2.8K20

    PostgreSQL JSON 和 JSONB 功能与不同

    下面是对比JSON & JSONB 之间不同 1 查询指定是否在JSON串 select * from json_test where jsonb_t @> '"foo"'::jsonb; select...我们可以看到,上面的查询JSONB 可以使用 @> 来查询JSON 串是否有指定,而JSON则不支持 select * from json_test where jsonb_t @> '[2,1]...2 索引 在对JSON支持POSTGRESQL 可以使用索引有BTREE ,GIN,HASH 等INDEX 1 GIN 索引在JSON 主要作用在查询你JOSN数据包含,索引是否可以在...GIN 索引所面对查询方式之一 就是判断是否在JSON串 1 JSON 是否存在这个KEY select * from json_test where jsonb_t ?...3 operators POSTGRESQL JOSN操作符比较多,让人眼花缭乱,而JOSN 和JOSNB之间区别也在于一些操作符支持 < less than > greater than

    2.1K20

    PostgreSQL基础(四):图形化界面安装与数据类型介绍

    图形化界面安装与数据类型介绍 一、图形化界面安装 图形化界面可以连接PGSQL很多,Navicat(收费)。 也可以直接使用PostgreSQL官方提供图形化界面。...(完全免费) 官方提供:pgAdmin - PostgreSQL Tools 直接点击就可以下载即可。...名称 说明 对比MySQL 布尔类型 boolean,标准布尔类型,只能存储true,false MySQL虽然没有对应boolean,但是有替换类型,数值tinyint类型,和PGSQLboolean...浮点 decimal,numeric(和decimal一样一样,精准浮点),real(float),double precision(double),money(货币类型) 和MySQL基本也没区别...几何类型 点,直线,线段,圆………… MySQL没有,但是一般开发也用不到 数组类型 在类型后,追加[],代表存储数组 MySQL没有~~~ JSON类型 json(存储JSON数据文本),jsonb

    15920

    Citus 分布式 PostgreSQL 集群 - SQL Reference(查询分布式表 SQL)

    SELECT http://www.postgresql.org/docs/current/static/sql-select.html 在以下部分,我们将讨论您可以使用 Citus 运行不同类型查询...它默认为 1000。 现实例子 现在来看一个更现实例子,说明 TopN 在实践是如何工作。让我们提取 2000 年亚马逊产品评论,并使用 TopN 快速查询。...另一方面,找到近似可以使用所谓 sketch 算法在 worker 节点上并行完成。 coordinator 节点然后将压缩摘要组合到最终结果,而不是读取完整行。...当在查询中使用扩展定义任何聚合时,Citus 将重写查询以将部分 tdigest 计算下推到适用 worker。 T-digest 精度可以通过传递给聚合 compression 参数来控制。...权衡是准确性与 worker 和 coordinator 之间共享数据量。有关如何在 tdigest 扩展中使用聚合完整说明,请查看官方 tdigest github 存储库文档。

    3.3K20

    Greenplum 对JSON支持(最新版)

    json) 把一个Json 最外层Object拆成key-value形式 5.2 获取JSON数据(去除双引号) 5.3 获取JSON数据KEY 5.4 返回JSON文本 6...3、json储存数据是对数据完整拷贝,会保留源数据空格/重复键以及顺序等,如果一个 JSON 对象包含同一个键超过一次,所有的键/对都会被保留。...JSON路径/项 <@ jsonb 左边JSON路径/是否包含在顶层右边JSON ?...text 字符串是否作为顶层键值存在于JSON ?| text[] 这些数组字符串任何一个是否作为顶层键值存在 ?...& text[] 这些数组字符串是否作为顶层键值存在 || jsonb 链接两个jsonb到新jsonb - text 层左操作删除键/对会字符串元素,基于键值匹配键/对 - integer

    3K00

    轻松入门 PostgreSQL for Beginners: A Step-by-Step Guide

    一、前言 图片 PostgreSQL(通常缩写为Postgres)是一种强大开源关系数据库管理系统(RDBMS),它具有许多先进功能和广泛应用领域。...PostgreSQL 是一个功能强大、高度可定制且可扩展关系数据库管理系统,适用于各种不同规模和类型应用程序和项目。...最终用户 希望社区长久,期望可以享受免费、可持续发展、开源、不被任何商业公司、不被任何国家控制企业级数据库。...5、PostgreSQL支持JSON和其他NoSQL功能,本机XML支持和使用HSTORE键值对。它还支持索引JSON数据以加快访问速度,特别是10版本JSONB更是强大。...总结 从应用场景来说,PG更加适合严格企业应用场景(比如金融、电信、ERP、CRM),但不仅仅限制于此,PostgreSQLjson,jsonb,hstore等数据格式,特别适用于一些大数据格式分析

    79432
    领券