imho.ws
IMHO.WS  

Вернуться   IMHO.WS > Компьютеры > Программирование
Опции темы
Старый 24.10.2002, 15:36     # 1
Starling
Guest
 
Сообщения: n/a

База данных - Access

Есть таблица Parent в базе данных

ID-----ParentID-----ParentName
0--------0-----------Главная1
1--------0-----------Главная2
2--------1-----------Дочерняя1
3--------2-----------ДочерняяДочерняя1
4--------1-----------Дочерняя2
5--------0-----------Главная3

Надо данные из таблицы вывести по порядку в виде дерева:

Главная 1
Главная 2
----------Дочерняя1
--------------------ДочеряяДочерняя1
----------Дочерняя2
Главная 3

Как это лучше(проще) всего сделать? Количество уровней от 3 до 5.
Можно это сделать каким-то хитрым запросом или писать скрипт? Как? 6 вложенных циклов?


Проект горит, помогите кто чем может, ссылками, идеями...
Спасибо
 
Старый 31.10.2002, 00:28     # 2
DmitryLV
Guest
 
Сообщения: n/a

Access DataBase

В общем-то не очень понятно, как ты хочешь выводить данные, но есть кое-что в самом Access. Если у тебя стоит Access 2000, то для наглядности создай пустую базу данных Blank Data Base, а затем запусти Мастера по созданию панелей переключателей (меню Tools->Database Utilities->Switchboard Manager), выполни его полностью и посмотри, что он натворит (таблицу, форму ...). Помоему это нечто похожее на то что тебе надо.
 
Старый 31.10.2002, 00:37     # 3
Starling
Guest
 
Сообщения: n/a

Спасибо за идею, обязательно гляну. На пока, я решил эту проблему вот таким кодом. Не гибко, но пока работает.

SELECT t1.ParentName, t2.ParentName, t3.ParentName
FROM (Parents AS t1 LEFT JOIN Parents AS t2 ON t1.ID=t2.ParentID) LEFT JOIN Parents AS t3 ON t2.ID=t3.ParentID
WHERE t1.ParentID=0;
 


Ваши права в разделе
Вы НЕ можете создавать новые темы
Вы не можете отвечать в темах.
Вы НЕ можете прикреплять вложения
Вы НЕ можете редактировать свои сообщения

BB код Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.

Быстрый переход


Часовой пояс GMT +4, время: 23:19.




Powered by vBulletin® Version 3.8.5
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.