Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Древовидные структуры, как сделать? 
V
    Опции темы
AKN
Дата 22.2.2006, 16:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 11.11.2005

Репутация: нет
Всего: нет



Господа, подскажите где почитать за древовидные структуры (создание, использование) - желательно для чайников.
PM MAIL   Вверх
Alexandr87
Дата 22.2.2006, 17:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


дыкий псых
***


Профиль
Группа: Завсегдатай
Сообщений: 1459
Регистрация: 27.11.2004
Где: Алматы, Казахстан

Репутация: нет
Всего: 39



а гугль зачем? Когда я не так давно искал - работал безотказно.

Обычно реализуется, созданием таблицы с полями id, parent_id, other_table_id.
Где id, parent_id - используются непосредственно для организации родительских отношений, а поле other_talbe_id - используется для связи непосредственно с данными в других таблицах. (Можно, конечно, вставить первые два поля в таблицу с данными).
Итак id - просто идентификатор записи. parent_id - ссылка на родителя. У корня id =0.
PM Jabber   Вверх
AKN
Дата 22.2.2006, 17:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 11.11.2005

Репутация: нет
Всего: нет



это я так понимаю с фиксированным значением вложенности, а если количество вложений заранее неизвестно?
например:


- водка -> водка луга-нова -> 0,5 л -> "водка луга-нова на бруньках"
- овощи -> капуста


т.е. у водки 3 материнских раздела, а у капусты только один.


Или я все неправильно понял?
PM MAIL   Вверх
UnixBeginner
Дата 22.2.2006, 18:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 89
Регистрация: 10.11.2005
Где: Россия, г. Калини нград

Репутация: нет
Всего: нет



делаешь просто таблице с полями id_parent - "узел более верхнео уровня" как сказали выше и просто id - идентификатор конкретного "узла". И всё - вот тебе таблица с неограниченной "древовидностью". ну еще каонечно таблица с данными для конкретного узла, но это уже как пожелаешь smile

ЗЫ. Еще правда таблица с id и название:
Код

1 - водка
2 - водка луга-нова
3 - 0,5 л
4 - "водка луга-нова на бруньках"
5 - овощи
6 - капуста


а дальше тадлица такая:
Код

id_parent     id
1                  2
2                  3
3                  4
5                  6

//ну можно еще и задать что для "родителей нет верхнего уровня"
-1                 1
-1                 5


Это сообщение отредактировал(а) UnixBeginner - 22.2.2006, 18:08
PM MAIL WWW ICQ   Вверх
Vit
Дата 23.2.2006, 05:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



Вообще-то в зависимости от требований... Например XML - типично древовидная структура


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
SergeBS
Дата 24.2.2006, 17:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1111
Регистрация: 10.6.2005
Где: Владимир

Репутация: 1
Всего: 22



AKN
ibase.ru - тот же Кузьменко - статья примерно так и называется "Создание древовидных структур". Ну короче найти ее там просто. Точно название не помню.
PM MAIL   Вверх
batigoal
Дата 26.2.2006, 23:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Только что наткнулся: http://sdm.viptop.ru/articles/sqltrees.html


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
YurikGL
Дата 5.3.2006, 20:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 196
Регистрация: 5.7.2005
Где: Уфа

Репутация: нет
Всего: 2



Цитата(SergeBS @ 24.2.2006, 17:07 Найти цитируемый пост)
ibase.ru - тот же Кузьменко - статья примерно так и называется "Создание древовидных структур". Ну короче найти ее там просто. Точно название не помню.



http://ibase.ru/develop.htm
Целый раздел с несколькими статьями по древовидным структурам.
--------------------
 
PM MAIL WWW ICQ   Вверх
SergeBS
Дата 6.3.2006, 09:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1111
Регистрация: 10.6.2005
Где: Владимир

Репутация: 1
Всего: 22



YurikGL,
А я что, я ничего smile. Мне это не надо.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1911 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.