微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Postgres将jsonb值串联/聚合为一个字符串

如何解决Postgres将jsonb值串联/聚合为一个字符串

我有一个带有entitiesjsonb的表dict,该列包含如下所述的语言环境:

{
  "fr": {
    "key1": "french1","key2": "french2"
  },"en": {
    "key1": "value1","key2": "value2","key3": "value3"
  }
}

在同一张表中,我创建了一个新的tsvectoren_locale,该列需要保存dict -> 'en'值的串联的tsvector。

对于上面的示例,我想实现以下内容:值的串联(不需要保留顺序):

value1 value2 value3值之间用空格隔开。

这是为了填充tsvectorto_tsvector('value1 value2 value3')

任何建议都会很棒!非常感谢!

解决方法

您的问题不清楚您到底想要什么。您只想根据问题的TITLE来串联dict -> 'en'中所有键的值。

所以试试这个:

select 
(select string_agg(j.value,' ') 
from jsonb_each_text(dict->'en') j) "values" from your_table

DEMO

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。