Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1341 / 920 / 265
Регистрация: 08.08.2014
Сообщений: 2,766

Выборка с условием по иерархической таблице

15.10.2024, 13:42. Показов 565. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть две таблицы:
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
create table item
(
    item_id int not null primary key,
    parent_item_id int null -- ссылается на саму себя, т.е. на 'item.item_id'
);
 
create table sub_item
(
    sub_item_id int identity (1, 1) not null primary key,
    item_id int not null, -- FK
 
    constraint fk_item_sub_item foreign key (item_id) references item (item_id)
);
И немного тестовых данных:
Кликните здесь для просмотра всего текста
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
insert into item values (1, null);
insert into item values (2, null);
insert into item values (3, 1);
insert into item values (4, 2);
insert into item values (5, 3);
insert into item values (6, 4);
insert into item values (7, null);
insert into item values (8, null);
insert into item values (9, 8);
insert into item values (10, 9);
 
insert into sub_item (item_id) values (1);
insert into sub_item (item_id) values (6);


При помощи такого запроса можно получить все записи из таблицы 'item', у которых есть хотя бы одна detail-запись в таблице 'sub_item' (в данном случае это будут 'item_id = 1' и 'item_id = 6'):
T-SQL
1
select * from item where exists (select 1 from sub_item where sub_item.item_id = item.item_id);
А как получить все 'select * from item'-записи по условию, что есть хотя бы одна detail-запись не только у самой записи, но и хотя бы у одной parent-записи на всей цепочке иерархии, вплоть до корневой записи (parent_item_id is null), т.е. при указанных тестовых данных этот будут записи 1, 3, 5 и 6.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.10.2024, 13:42
Ответы с готовыми решениями:

Как сделать отчет по иерархической таблице
Уважаемые, Gurus! Подскажите, если не сложно, как сделать отчет по иерархической таблице. Число уровней вложенности может своим для...

Триггер для контроля циклов в иерархической таблице
Доброго времени суток, господа! Стоит следующая задача: имеется таблица Departments. CREATE TABLE DEPARTMENTS (ID NUMBER, ...

Выборка без ключевых слов/Выборка без столбцов/Выборка с условием
Нужно сделать 2 типа выборки в отдельный столбец: #1 без ключевых слов типа "АРБУЗ, ДЫНЯ" #2 без данных содержащихся в трех...

3
668 / 291 / 120
Регистрация: 12.04.2022
Сообщений: 1,000
15.10.2024, 15:11
Цитата Сообщение от kotelok Посмотреть сообщение
т.е. при указанных тестовых данных этот будут записи 1, 3, 5 и 6.
Не понятно, почему выпали записи item_id = 4 и 2, которые являются веткой "в верх" потомка 6.

T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
with cte as 
(
select item_id, parent_item_id  from item where exists (select 1 from sub_item where sub_item.item_id = item.item_id)
union all
select item.item_id, item.parent_item_id from cte
inner join item on item.parent_item_id = cte.item_id
)
, 
cte2 as 
(
select item_id, parent_item_id  from item where exists (select 1 from sub_item where sub_item.item_id = item.item_id)
 
union all
select item.item_id, item.parent_item_id from cte2
inner join item on cte2.parent_item_id = item.item_id
)
 
select * from cte2
union 
select * from cte order by parent_item_id, item_id
1
1341 / 920 / 265
Регистрация: 08.08.2014
Сообщений: 2,766
15.10.2024, 15:17  [ТС]
Цитата Сообщение от PaulWist Посмотреть сообщение
Не понятно, почему выпали записи item_id = 4 и 2
Потому что я, видимо, не совсем понятно задачу сформировал.

Запись должна попадать в выборку при условии что хотя бы одна detail-запись есть:
1. Либо у неё самой.
2. Либо у одного из её предков (на любую глубину).

Наличие detail-записей у потомков этой записи на выборке никак сказываться не должно.
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
15.10.2024, 15:17
Лучший ответ Сообщение было отмечено kotelok как решение

Решение

SQL
1
2
3
4
5
6
7
8
9
10
WITH cte AS
(SELECT i.*,CASE WHEN s.item_id IS NOT NULL THEN 1 ELSE 0 END priz 
   FROM item i 
     LEFT JOIN sub_item s ON s.item_id=i.item_id 
   WHERE i.parent_item_id IS NULL
 UNION ALL
 SELECT i.*,CASE WHEN cte.priz=1 OR EXISTS(SELECT 8 FROM sub_item s WHERE s.item_id=i.item_id) THEN 1 ELSE 0 END priz
   FROM item i
     INNER JOIN cte ON cte.item_id=i.parent_item_id)
SELECT item_id,parent_item_id FROM cte WHERE priz=1 ORDER BY item_id
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.10.2024, 15:17
Помогаю со студенческими работами здесь

Выборка задолженностей по таблице (выборка строк с пустыми ячейкам даты оплаты) для отчета
Имеется таблица учета продаж, в ней нужно сделать выборку по дате оплаты для ежемесячного отчета. То есть, вначале ввести дату начала...

Выборка с условием
Доброе время суток всем. Проблема в следующем. Есть кусок кода который делает запрос к БД, и все работает. Далее на подобии того кода делаю...

Выборка с условием
Доброго времени суток форумчанам! Такая задача сложилась, нужно сделать выборку с "условием". Допустим есть поле -...

Выборка с условием
если делать запрос в базу с интерфейса vs, то получается вот что: SELECT , , , , FROM WHERE ( = @theCat) ORDER BY а мне необходимо...

Выборка с условием
Приветствую. Можно ли построить запрос на выборку со следующим условием: если значение поля в таблице равно 0 тогда вычислить поле по...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru