我刚刚开始在 postgres 上使用 jsonb 并在网上很难找到示例,因为它是一个相对较新的概念。我正在尝试使用 jsonb_each_text 打印出键和值表,但在单个列中获取 csv。
我将以下 json 保存为 jsonb 并使用它来测试我的查询。
{
"lookup_id": "730fca0c-2984-4d5c-8fab-2a9aa2144534",
"service_type": "XXX",
"metadata": "sampledata2",
"matrix": [
{
"payment_selection": "type",
"offer_currencies": [
{
"currency_code": "EUR",
"value": 1220.42
}
]
}
]
}
我可以通过以下方式访问 offer_currencies 数组
SELECT element -> 'offer_currencies' -> 0
FROM test t, jsonb_array_elements(t.json -> 'matrix') AS element
WHERE element ->> 'payment_selection' = 'type'
结果为“{”value”:1220.42,“currency_code”:“EUR”}”,所以如果我运行以下查询,我会得到(我必须将“更改为”)
select * from jsonb_each_text('{"value": 1220.42, "currency_code": "EUR"}')
Key | Value
---------------|----------
"value" | "1220.42"
"currency_code"| "EUR"
所以使用上述理论我创建了这个查询
SELECT jsonb_each_text(data)
FROM (SELECT element -> 'offer_currencies' -> 0 AS data
FROM test t, jsonb_array_elements(t.json -> 'matrix') AS element
WHERE element ->> 'payment_selection' = 'type') AS dummy;
但这会在一列中打印 csv
record
---------------------
"(value,1220.42)"
"(currency_code,EUR)"