1341 / 920 / 265
Регистрация: 08.08.2014
Сообщений: 2,768

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

15.10.2024, 13:42. Показов 581. Ответов 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
671 / 294 / 120
Регистрация: 12.04.2022
Сообщений: 1,003
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,768
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru