Невозможно преобразовать данные в ожидаемый формат в снежинке

Я получил данные в строках для такого столбца

[
  {
    "value": "A",
    "path": "nth-child(1)"
  },
  {
    "value": "K",
    "path": "nth-child(2)"
  },
  {
    "value": "C",
    "path": "nth-child(3)"
  }
]

Нужна помощь ..... Хотите получить данные в таком формате в строках из этого столбца

   {
     "A",
     "K",
     "C",   
  },

Пробовали так: но он объединяет все строки таблицы

SELECT LISTAGG(f.value:value::STRING, ',') AS col
FROM tablename
,LATERAL FLATTEN(input => parse_json(column_name)) f 

Пожалуйста, уточните, что вам нужно. Похоже, вы говорите, что значения должны быть по одному набору на строку в зависимости от строки, из которой они были получены в JSON. Если это так, вы можете сгруппировать по SEQ, который является автоматически сгенерированным столбцом в функции FLATTEN.

Greg Pavlik 17.05.2022 04:36

Вы пытались добавить «группировать по последовательностям», если это то, что вы ищете?

Pankaj 17.05.2022 04:36
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
1
2
33
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я использовал CTE только для предоставления поддельных данных для примера:

WITH data(json) as (
    select parse_json(column1) from values
    ('[{"value":"A","path":"nth-child(1)"},{"value":"K","path":"nth-child(2)"},{"value":"C","path":"nth-child(3)"}]'),
    ('[{"value":"B","path":"nth-child(1)"},{"value":"L","path":"nth-child(2)"},{"value":"D","path":"nth-child(3)"}]'),
    ('[{"value":"C","path":"nth-child(1)"},{"value":"M","path":"nth-child(2)"},{"value":"E","path":"nth-child(3)"}]')
)
SELECT LISTAGG(f.value:value::text,',') as l1
from data as d
   ,table(flatten(input=>d.json)) f
group by f.seq
order by f.seq;

дает:

L1
А, К, С
Б, Л, Д
С, М, Э

Таким образом, с некоторой конкатенацией строк через ||

SELECT '{' || LISTAGG('"' ||f.value:value::text|| '"' , ',') || '}' as l1
from data as d
   ,table(flatten(input=>d.json)) f
group by f.seq
order by f.seq;

дает:

L1
{"А","К","С"}
{"Б","Л","Д"}
{"С","М","Е"}

сработало, но то же выражение, как использовать «группировать по» с другими столбцами?

user19131919 17.05.2022 09:00

@user19131919 user19131919 не совсем понимаю, что вы имеете в виду. Задайте новый вопрос с теми же данными формы «у меня есть это, но что это такое».

Simeon Pilgrim 17.05.2022 10:42

Другие вопросы по теме