Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Написать непростой запрос 
:(
    Опции темы
polin11
Дата 8.11.2021, 02:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 125
Регистрация: 6.6.2015

Репутация: нет
Всего: нет



Использую СУБД Postgresql, есть таблица

https://www.db-fiddle.com/f/3ERqNCRRXJh5yEJvDtJMQf/0

Выделить всёкод SQL
1:
2:
3:
4:
5:
6:
7:
CREATE TABLE forms (
    id serial PRIMARY KEY,
    account int not null,
    author text,
    doc int NOT NULL,
    users text[]
);

нужно получить результат следующего вида 

Выделить всёPython
1:
author : {account: [users]}



insert into  forms(account, author, doc, users) values 
Выделить всёкод SQL
1:
2:
3:
4:
5:
6:
(1, 'Иванов', 3, array['Петя''Вася']),
(1, 'Иванов', 3, array['Иван']),
(2, 'Иванов', 3, array['Иван']),
(2, 'Сергеев', 3, array['Павел']),
(2, 'Сергеев', 3, array['Роман']),
(1, 'Сергеев', 3, array['Коля' 'Дима'])



для предыдущего набора должны получить такой результат
Выделить всёPython
1:
2:
'Иванов'{1['Петя''Вася''Иван']2['Иван']},
'Сергеев'{1['Коля' 'Дима']2['Павел''Роман']}



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

Нужна конструктивная идея как написать такой запрос
PM MAIL   Вверх
Akina
Дата 8.11.2021, 08:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 3
Всего: 454



Выделить всёкод SQL
1:
2:
3:
4:
5:
6:
7:
WITH cte AS SELECT forms.account, forms.author, array_agg(users.name) users
              FROM forms
              CROSS JOIN UNNEST(users) AS users (name)
              GROUP BY forms.account, forms.author )
SELECT json_build_object(author, json_object_agg(account, users)) output
FROM cte
GROUP BY author;

DEMO fiddle
Ну или так же, но с массивами.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PostgreSQL | Следующая тема »


 




[ Время генерации скрипта: 0.0581 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.