Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
1 / 1 / 1
Регистрация: 24.03.2013
Сообщений: 178

Написать непростой запрос

08.11.2021, 02:43. Показов 662. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Использую СУБД Postgresql, есть таблица

https://www.db-fiddle.com/f/3E... JvDtJMQf/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]}

SQL
1
2
3
4
5
6
7
INSERT INTO  forms(account, author, doc, users) VALUES 
(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: ['Павел', 'Роман']}

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

Нужна конструктивная идея как написать такой запрос
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.11.2021, 02:43
Ответы с готовыми решениями:

Непростой запрос на выборку
Возможно кто-нибудь сможет подсказать, с помощью чего решить задачку. В базе данных есть таблица "Условия поставок", которая...

Непростой запрос из двух таблиц
Есть одна таблица (id, id от кого, id кому, что-то). И вторая таблица с пользователями, но пользователи равноценны (кому и от кого),...

Непростой запрос для меня
Народ, помогите, пожалуйста!!!!!!!!!! Есть БД Oracle. Надо написать запрос, который делает следующее: 1) Данные, которые выделенные ...

3
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
08.11.2021, 09:39
не понятен принцип объединения Иванов, Павлов, Романов и пр. в массивы. Почему Иваны так объединены, а Павел И Роман по другому?
0
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
08.11.2021, 16:22
Аватар, см. первое поле account

polin11, Используйте функции json_build_object и тому подобные, чтобы создать нужный вам JSON
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
09.11.2021, 08:58
типа такого что-то
SQL
1
2
3
4
5
6
7
SELECT json_build_object(v.author, json_object_agg(v.account,v.ar))
  FROM
    (SELECT author,account,array_agg(u) ar
       FROM forms,unnest(users) u
       GROUP BY author,account
       ORDER BY author,account) v
  GROUP BY v.author
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.11.2021, 08:58
Помогаю со студенческими работами здесь

Непростой запрос на определение победителей
Уважаемые гуру sql, прошу вашей помощи в написании запроса. В общем суть такая, --проводится выставка собак, выставляются очки за...

Есть запрос на вставку в PostgreSQL нужно написать этот запрос в Python
Есть запрос на вставку в PostgreSQL нужно написать этот запрос в Python INSERT INTO "table1" ("ID_table3",...

Непростой калькулятор
Здравствуйте,подскажите мне пожалуйста,нужно сделать калькулятор,но не простой,нужно например , найти S,для этого Кзаполн разделить на w22 ...

Непростой таймер С++
Здравствуйте! У меня, как оказалось, непростая задача: Написать таймер, который будет совершать действие при соблюдении условия в...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru