Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/18: Рейтинг темы: голосов - 18, средняя оценка - 4.72
17 / 17 / 1
Регистрация: 22.02.2012
Сообщений: 116

Выборка всех родительских узлов в дереве

11.07.2013, 20:38. Показов 3377. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В таблице
T-SQL
1
2
3
4
5
6
CREATE TABLE Nodes 
(
   ID int PRIMARY KEY INDENTITY(0,1) not null,
   Name varchar(50) not null, 
   ParentID int not null CONSTRAINT ParentNode REFERENCES Nodes(ID)
)
содержатся записи о всех узлах дерева, схожего с деревом каталогов Windows. Нужна возможность работы пользователя только с теми узлами, которые для него доступны. Записи о том кому какие узлы доступны для просмотра содержатся в таблице
T-SQL
1
2
3
4
5
CREATE TABLE VisibleNodes
(
    NodeID int not null CONSTRAINT Node REFERENCES Nodes(ID),
    UserID int not null  CONSTRAINT User REFERENCES Users(ID)
)
.
Выборка доступных узлов происходит таким образом:
T-SQL
1
2
3
4
SELECT Nodes.ID, Nodes.Name, Nodes.ParentID FROM Nodes
              INNER JOIN VisibleNodes
              ON Nodes.ID = VisibleNodes.NodeID 
              WHERE VisibleNodes.UserID = @UserID
В таком случае выбираются все доступные для пользователя узлы,но их родительские не выбираются.
Как реализовать выборку еще и всех родительских узлов? Ведь я не могу показать в дереве дочерние узлы без родительских. Вариант записывать в таблицу VisibleNodes также и родительские узлы не подходит т.к. запись означает не только возможность увидеть, но и просматривать данные связанные с этим узлом. К тому же, это усложняет логику программы.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.07.2013, 20:38
Ответы с готовыми решениями:

По заданным значениям N рассчитать число всех узлов с глубиной N в заданном дереве.Код есть
По заданным значениям N рассчитать число всех узлов с глубиной N в заданном дереве. Помогите с заданием пожалуйста. Дерево есть: #include...

Подсчет родительских узлов
Есть например вот такая разметка страницы. <select></select> <hr> <DIV> <div></div> <div></div> ...

Добавление родительских и дочерних узлов treeview
Всем привет! нашел статью где описано добавление данных в treeview но оно мне не очень подходит TreeNode tovarNode = new...

3
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
11.07.2013, 21:34
WITH обобщенное_табличное_выражение (Transact-SQL)
Рекурсия от видимых узлов по всем узлам вверх до корня
1
17 / 17 / 1
Регистрация: 22.02.2012
Сообщений: 116
13.07.2013, 10:00  [ТС]
cygapb-007, спасибо. Три дня разбирался, но успешно.

Добавлено через 3 минуты
Кстати, в тех случаях когда программа не выходила из цикла, выдавалось сообщение что предел рекурсивных вызовов 100. У меня вряд-ли будет такая сложность вложений, но все же интересно 100 - это окончательный предел или можно увеличить настройками?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
13.07.2013, 11:31
Цитата Сообщение от Фальцлюфт Посмотреть сообщение
У меня вряд-ли будет такая сложность вложений, но все же интересно 100 - это окончательный предел или можно увеличить настройками?
Из статьи по вышеприведенной ссылке:
To prevent an infinite loop, you can limit the number of recursion levels allowed for a particular statement by using the MAXRECURSION hint and a value between 0 and 32,767 in the OPTION clause of the INSERT, UPDATE, DELETE, or SELECT statement.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.07.2013, 11:31
Помогаю со студенческими работами здесь

Как правильно обойти TreeView и вывести текст родительских и дочерних узлов
Как правильно обойти TreeView в WPF и вывести текст родительских и дочерних узлов? Причем к каждому узлу добавлено ещё два дочерних узла...

Удаление всех узлов и защита от отсутствие узлов в односвязном списке
Здравствуйте. Помогите мне пожалуйста разобраться с проблемой. У меня получилось сделать добавление узла (в начало, в конец, перед и после...

Посчитать число узлов и листьев в дереве
Помогите подсчитать число узлов и листьев в дереве. Заранее благодарен.

Определить максимальное количество дочерних узлов в дереве
Добрый вечер. Требуется написать программу, определяющую максимальное количество дочерних узлов в дереве. Спасибо

Поиск суммы последовательных узлов в бинарном дереве
Дано: бинарное дерево (Например созданное по этому алгоритму). Число S. Нужно найти последовательность узлов (только с вверху вниз или...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru