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

Сложный запрос

07.06.2016, 11:42. Показов 1721. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Подскажите пожалуйста, как реализовать следующее.

В базе есть перечень таблиц, в которых различные поля, но есть список полей, в котором, по крайне мере, несколько гарантированно находятся в таблицах. Это поля 'id', 'code', 'name', 'number', 'source1_code', 'source2_code'.

То есть в некоторых таблицах есть поля 'id', 'code', 'name', в других 'id', 'source1_code', 'source2_code'. Могут быть и другие комбинации.

Подскажите пожалуйста, как в результате получить таблицу с колонками:
table_name, 'id' 'code', 'name', 'number', 'source1_code', 'source2_code'.

Где table_name - название таблицы в базе, а другие колонки могут принимать значения 0 или 1; 1 - означает, что данная колонка есть в таблице, 0 - если этой колонки нет в таблице.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.06.2016, 11:42
Ответы с готовыми решениями:

сложный запрос
есть 2 таблицы: в таблице contract в поле ref_prize находятся значения id из таблицы prize. есть записи как повторяющиеся так и нет. ...

Сложный SQL запрос
Добрый день. Подскажите, пожалуйста, как исправить SQL запрос, чтобы получить данные указанные на прилагаемой картинке. Если убрать AND...

Сложный запрос с датами
Доброго времени суток! Помогите, пожалуйста решить следующую проблему. Есть три таблицы: Income (приход деталей, содержит инфо о...

3
1263 / 977 / 384
Регистрация: 02.09.2012
Сообщений: 3,020
07.06.2016, 12:14
Непонятно, вы хотите узнать какие колонки у вас в таблицах базы?????
Вот такой запрос не подойдет для начала (укажите верно имя вашей схемы, если не public)
SQL
1
2
SELECT TABLE_NAME, column_name, data_type FROM information_schema.columns
WHERE table_schema='public';
0
49 / 49 / 3
Регистрация: 15.11.2009
Сообщений: 372
07.06.2016, 12:36  [ТС]
Мне необходимо сформировать таблицу, структуру которой я описал выше.

На основе данной таблицы, я планирую сформировать динамические запросы для добавления записей именно в те колонки, напротив которых стоит 1.
0
1263 / 977 / 384
Регистрация: 02.09.2012
Сообщений: 3,020
07.06.2016, 16:17
Лучший ответ Сообщение было отмечено Helios1.618 как решение

Решение

Сообразил. По сути результирующая таблица - это шахматка ('pivot table'). В стандартном SQL, насколько мне известно, еще нет способов делать такие запросы. Споров и разговоров по этому поводу очень много, но из всего можно выделить два способа построения: 1. создаете временную таблицу нужной вам структуры и хранимой процедурой ее заполняете так, как вам надо; 2. используете различные расширения, предусмотренные в СУБД.

В postgresql таким расширением является tablefunc.

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

Добавлено через 5 минут
Вот, примерьте для себя
SQL
1
2
3
4
5
SELECT * FROM crosstab(
$$select TABLE_NAME::text, column_name::text, 1  FROM information_schema.columns WHERE table_schema='public'$$,
$$select * FROM (VALUES('id'), ('f1'), ('cnt')) AS t(cat)$$
)
AS ct(row_name text, cat_id INT, cat_f1 INT, cat_cnt INT);
Не совсем то, что нужно с 0 и 1. Но для начало должно быть похоже на правду
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.06.2016, 16:17
Помогаю со студенческими работами здесь

сложный запрос в postgre
Здравствуйте. Помогите пожалуйста составить SQL запрос для POSTGRE. Есть таблицы Table ds id nazv 1 obj1 2 obj2 ...

Сложный SQL запрос
Добрый день. Устройство присылает сигналы в три колонки T, H, P. При первом запуске приходят все три значения. Пример значений: 24.18 ...

Сложный запрос из одной таблицы с предварительной обработкой данных
Ребята не очень силен в запросах и токо начал осваивать постгри. есть таблица структура: camid- камера id, action-(принимает attach или...

сложный запрос (для меня сложный)
Есть таблица с продажами услуг от разных фирм, есть таблица с оплатой за предоставленные услуги (при этом сумма оплат может не совпадать с...

Сложный запрос
SELECT * FROM facts WHERE DATE(date) BETWEEN date1 AND date2 Использую вот такой запрос ,но помимо выборки по дате нужно выбирать еще по...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru