467 / 344 / 19
Регистрация: 26.05.2009
Сообщений: 2,696
1

Как правильно организовать БД?

27.12.2012, 18:01. Показов 2383. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть база данных о предприятии. В ней есть данные об отделах и о сотрудниках. С сотрудниками всё понятно - сделаю столбец для id отдела, в котором он работает. Проблема с отделами, т.к. их структура иерархическая. Думаю сделать отделы справочником, а в таблице хранить в поле записи типа "1-3-4" (1й отдел входит в 3й, который входит в состав 4го). Правильно ли это? Или в БД есть какие-то другие приемы для хранения иерархии однотипных объектов?

Добавлено через 1 час 25 минут
Неужели никто не подскажет?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.12.2012, 18:01
Ответы с готовыми решениями:

Есть над чем подумать или как правильно организовать структуру БД
Кому по зубам такая задачка? Часть первая: Например у нас есть сущность "Товары". Данные о...

Как правильно организовать отношение между таблицами(тематика: График работы сотрудника).
Добрый день! Народ есть такая проблема, с которой я изменяю жене, работе и жизни в целом. Но...

Как организовать правильно запрос
Доброго всем. Никак не могу понять, как ЭТО сделать... Есть таблица, есть форма с запросом. Идет...

Как правильно организовать БД из 4-х таблиц?
ИСПОЛЬЗУЕТСЯ: Access Имеется три таблицы: - 00_tb1; - 00_tb2; - 00_tb3; ...

2
912 / 877 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
28.12.2012, 08:25 2
Организация деревьев в БД - тема не тривиальная. Есть несколько подходов. Одни проще для восприятия, но тормознее в работе, другие за счет избыточности дают более удобные или быстрые методы обработки данных.
Что-либо советовать не буду, для начала ознакомтесь с теорией вопроса, хотя бы по одной из трех статей ниже. Осилите все три - будете разбираться в вопросе лучше, чем 90% здешних тусовщиков
Joe Celko. Деревья в SQL. Части 1, 2, 3 <= считается "классикой"
Д.Кузьменко. Древовидные (иерархические) структуры данных в реляционных базах данных. Части 1 и 2
А.Киреев. Деревья в SQL
1
2708 / 1791 / 194
Регистрация: 05.06.2011
Сообщений: 5,184
11.01.2013, 14:39 3
Цитата Сообщение от body90 Посмотреть сообщение
Неужели никто не подскажет?
За час 25 мин -- наверное, никто
Есть пара способов, аналогичных, в общем-то, твоему, но покомпактнее, не нашёл их в статьях. Один нгазывается, по-моему, круги Фоули, хотя в гугле навскидку сейчас не нашёл. На рациональных числах вводится бесконечная древесная структура, и каждой записи сопоставляется рациональное число, которое и задаёт место узла в дереве. Бонус -- имеем дерево с упорядоченными детьми каждой вершины.
По идее, пара аналогичных способов, но до подробно не разбирался: положение в иерархии -- битовая строка. На каждый отрезок пути два бита: 01 -- вниз, 10 -- вправо (к следующему потомку того же уровня), 11 -- лист. Либо, например, по биту 0 -- вниз, 1 -- вправо + в отдельном поле длина пути.
0
11.01.2013, 14:39
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
11.01.2013, 14:39
Помогаю со студенческими работами здесь

Как правильно организовать связь: таблица Анкета и поле Рейтинг таблицы Передачи?
Мне нужно поместить среднее значение рейтинга, конкретной передачи, из таблицы Анкета в поле...

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

Роли (Админ, Пользователь, Модератор), как организовать правильно?
Добрый день! Пишу клиент-серверное приложение , возник такой вопрос: Как организовать роли в...

Как правильно организовать?
У меня есть несколько классов и у них практически одинаковые функции, которые отличается парой...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru