Postgresql строка для jsonb_each_text () - PullRequest
0 голосов
/ 04 августа 2020

У меня есть эта строка (с разными символами) как значение строки в Postgresql:

{'img_0': 'https://random.com/xxxxxx.jpg', 'img_1': 'https://random.com/yyyyyy.jpg', 'img_2': 'https://random.com/zzzzzz.jpg'}

Я пытаюсь использовать json_eact_text (), но не могу понять, как это сделать. Я пробовал to_jsonb () на нем (работает), а затем jsonb_each (), но у меня есть эта ошибка:

ERROR:  cannot call jsonb_each on a non-object

Мой запрос:

WITH 
test AS (
    SELECT to_jsonb(value) as value FROM attribute_value WHERE id = 43918
)

SELECT jsonb_each(value) FROM test

1 Ответ

1 голос
/ 04 августа 2020

Ваше текстовое значение недействительно JSON. JSON требует двойных кавычек (") для разделения строк.

Это будет работать путем исправления вашего текста при условии, что ваши данные постоянно неверны:

with t (sometext) as (
  values ($${'img_0': 'https://random.com/xxxxxx.jpg', 'img_1': 'https://random.com/yyyyyy.jpg', 'img_2': 'https://random.com/zzzzzz.jpg'}$$)
)
select jsonb_each_text(replace(sometext, '''', '"')::jsonb)
  from t;

            jsonb_each_text            
---------------------------------------
 (img_0,https://random.com/xxxxxx.jpg)
 (img_1,https://random.com/yyyyyy.jpg)
 (img_2,https://random.com/zzzzzz.jpg)
(3 rows)

Чтобы разбить это на столбцы :

with t (sometext) as (
  values ($${'img_0': 'https://random.com/xxxxxx.jpg', 'img_1': 'https://random.com/yyyyyy.jpg', 'img_2': 'https://random.com/zzzzzz.jpg'}$$)
)
select j.*
  from t
 cross join lateral jsonb_each_text(replace(sometext, '''', '"')::jsonb) as j;

  key  |             value             
-------+-------------------------------
 img_0 | https://random.com/xxxxxx.jpg
 img_1 | https://random.com/yyyyyy.jpg
 img_2 | https://random.com/zzzzzz.jpg
(3 rows)
...