Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 13.09.2020
Сообщений: 9

Рекурсивный запрос с выводом иерархии и номером узла в ней

27.09.2020, 23:16. Показов 2787. Ответов 2

Студворк — интернет-сервис помощи студентам
Здравствуйте! Пытаюсь начать разбираться в простейших запросах в PostgreeSQL. Помогите, пожалуйста, составить хотя бы пару первых рекурсивных запросов для ориентиру. У самого никак не получается (либо выводится все, но только не то, что нужно).

По идее, задание включает составление 4-х запросов. Было бы хорошо, если бы мне кто - то помог со всеми , но в принципе, я попробую и на основе двух первых разобраться. Вот задания:

1) Сформировать запрос, выводящий фамилию сотрудника, номер узла иерархии и имена всех его менеджеров через знак '/'.
2) Сформировать запрос, выводящий фамилию сотрудника, номер и название подразделения, где он работает, номер узла иерархии и имена всех его менеджеров через '/'.
3) Сформировать запрос, выводящий фамилию сотрудника, номер и название подразделения, где он работает, номер узла иерархии и имена всех его менеджеров через /. Внутри одного уровня иерархии сотрудники должны быть отсортированы по названиям подразделения.
4) Сформировать запрос, выводящий фамилию сотрудника, номер узла иерархии и имена всех его менеджеров через /, исключая фамилию самого сотрудника.

Во вложениях - скрины табличек.

Буду ОЧЕНЬ благодарен!!
Миниатюры
Рекурсивный запрос с выводом иерархии и номером узла в ней  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.09.2020, 23:16
Ответы с готовыми решениями:

Запрос по иерархии справочника
Здравствуйте! есть такая проблема: есть справочник "СпецификацияНоменклатуры" в нем табличная часть "ИсходныеКомплектующие",...

Матрица: строку с номером n сделать столбцом с номером n, а столбец с номером n- строкой с номером n
Дана действительная квадратная матрица порядка n. Преобразовать матрицу по следующему правилу: строку с номером n сделать столбцом с...

при запросе вида «script.php?id=ЗАПРОС» выводить статью под номером «ЗАПРОС»
Написать php-скрипт, который при запросе вида «script.php?id=ЗАПРОС» будет выводить в браузер статью, хранящуюся в базе под номером...

2
0 / 0 / 0
Регистрация: 13.09.2020
Сообщений: 9
28.09.2020, 10:52  [ТС]
Вот мой первый запрос, но он неверный, выделяется ошибка на строке "ON r."EMPNO" = E2."MGR". Ошибка такая:
ERROR: ОШИБКА: в элементе предложения FROM неверная ссылка на таблицу "e2". Не могу понять, что не так.

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
WITH RECURSIVE r ("EMPNO", "ENAME", "MANAGER_NAME", PATH, LEVEL) AS(
    SELECT E."EMPNO", E."ENAME", MANAGER."ENAME", CAST (E."EMPNO" AS VARCHAR(50)) AS PATH, 0
    
    FROM "EMP" E, "EMP" MANAGER
    WHERE E."MGR" IS NULL AND E."MGR" = MANAGER."EMPNO"
    
    UNION
    
    SELECT E2."EMPNO", E2."ENAME", MANAGER2."ENAME", CAST (r.PATH||'/'||E2."EMPNO" AS VARCHAR(50)), LEVEL + 1
    FROM "EMP" E2, "EMP" MANAGER2
    INNER JOIN r
        ON r."EMPNO" = E2."MGR"
    
)
 
SELECT * FROM r
0
1264 / 978 / 384
Регистрация: 02.09.2012
Сообщений: 3,021
01.10.2020, 22:18
Лучший ответ Сообщение было отмечено Che_S_ter как решение

Решение

По скриншотам никто ничего делать не будет.
Переведите в текстовый вариант, чтобы можно было работать с Вашими данными в sqlfiddle, например.

По ошибке... У вас неправильно JOIN-ы написаны.
Считайте, что парсер вот так как бы расставит скобки
T1, (T2 INNER JOIN T3 ON T3.xxx = T1.yyy)
На T1 ссылаться нельзя.

Вообще плохой тон, перемешивать под FROM соединение таблиц через запятую и через JOIN. Считайте, что запятая - это CROSS JOIN или INNER JOIN ON (TRUE)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.10.2020, 22:18
Помогаю со студенческими работами здесь

Рекурсивный обход. Не могу сделать табуляцию. Обход с выводом имен файлов
Задание простое, ну по крайней мере на первый взгляд. Написать скрипт обхода вложенных директорий с выводом дерева (табулированного, то...

Преобразуйте матрицу по правилу: строку с номером P сделайте столбцом с номером P, а столбец с номером P сделайте строкой с номером P
Дана матрица А(N, N) и целое P. Преобразуйте матрицу по правилу: строку с номером P сделайте столбцом с номером P, а столбец с номером P...

Преобразовать матрицу по правилу: строку с номером n сделать столбцом с номером n, а столбец с номером n сделать строкой с номером n
Дана действительная квадратная матрица порядка n. Преобразовать матрицу по правилу: строку с номером n сделать столбцом с номером n, а...

Рекурсивный запрос
Имеются таблицы «Группы прейскуранта», «Партнеры», «Заметки». Таблица заметки хранит связь между партнером и группой прейскуранта, с...

Рекурсивный запрос
Добрый день. Есть таблица: Есть 3 типа описания столбцов: 1. Страна (Type_id = 1); 2. Область / Штат 3. Город Нужно...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru