问题描述
我有一个带有entities
列jsonb
的表dict
,该列包含如下所述的语言环境:
{
"fr": {
"key1": "french1","key2": "french2"
},"en": {
"key1": "value1","key2": "value2","key3": "value3"
}
}
在同一张表中,我创建了一个新的tsvector
列en_locale
,该列需要保存dict -> 'en'
值的串联的tsvector。
对于上面的示例,我想实现以下内容:值的串联(不需要保留顺序):
value1 value2 value3
值之间用空格隔开。
这是为了填充tsvector
列to_tsvector('value1 value2 value3')
任何建议都会很棒!非常感谢!
解决方法
您的问题不清楚您到底想要什么。您只想根据问题的TITLE
来串联dict -> 'en'
中所有键的值。
所以试试这个:
select
(select string_agg(j.value,' ')
from jsonb_each_text(dict->'en') j) "values" from your_table