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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проектирование связи, книжный магазин 
V
    Опции темы
Keeper89
Дата 1.5.2009, 15:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Доброго времени суток!

Проектирую БД книжного магазина. У каждой книги часто бывает несколько авторов. Как лучше организовать в базе такое хранение информации автор-книга?

Заранее, спасибо.


--------------------
PM MAIL WWW   Вверх
Gluttton
Дата 1.5.2009, 17:10 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Начинающий
***


Профиль
Группа: Завсегдатай
Сообщений: 1170
Регистрация: 28.8.2008
Где: Феодосия

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



Один и тот же автор может быть автором различных книг, а в свою очередь, каждая из книг может быть написана разными авторами - классический М:М. Для физической реализации необходимо ввести дополнительную таблицу и создать к ней связи 1:М от обоих таблиц, что то вроде такого:

user posted image

Google подсказывает.

Это сообщение отредактировал(а) Gluttton - 1.5.2009, 17:16


--------------------
Слава Україні!
PM MAIL   Вверх
Keeper89
Дата 1.5.2009, 19:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Цитата(Gluttton @  1.5.2009,  17:10 Найти цитируемый пост)
классический М:М. Для физической реализации необходимо ввести дополнительную таблицу и создать к ней связи 1:М от обоих таблиц, что то вроде такого:

Связь, М:М, это понятно. Что сделать лучше: завести таблицу для каждого автора с идентификаторами книг или две отдельные таблицы книг и авторов и третью для связей?


--------------------
PM MAIL WWW   Вверх
Gluttton
Дата 1.5.2009, 19:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Начинающий
***


Профиль
Группа: Завсегдатай
Сообщений: 1170
Регистрация: 28.8.2008
Где: Феодосия

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



Цитата

завести таблицу для каждого автора с идентификаторами книг


В результате денормализации возникает избыточность, но и упрощается работа с БД (запросы составлять легче и выполняються они быстрее).

Цитата

или две отдельные таблицы книг и авторов и третью для связей


Если очевидно, что "Авторы" и "Книги" отдельные сущности со своими набороми атрибутов, то не вижу способа смысла! smile (очепятался) отказываться от реализации двумя+одна таблицами.

А вообще, сложно сказать (во всяком случае мне smile ) не зная контекста задачи (предпологаемое количество записей, информацию, которую нужно хранить в БД).

Если БД должна хранить об авторах только Ф.И.О., то я бы не стал создавать отдельную таблицу для них, т.к. фактичиески эта информация является атрибутом сущности "Книга". Но! В этом случае мне прийдется вводить новую книгу в БД, ровно столько раз, сколько у нее авторов (хотя можно и всех авторов одной строкой заносить - всё зависит от требований к создаваемой БД).

А если БД должна хранить дату рождения автора, место жительство и биографию smile , то я бы создал отдельную таблицу, т.к. если этого не сделать, то при вводе новой книги в БД, нужно будет потрудиться и ввести все остальные данные (дату рождения и биографию автора).

Это сообщение отредактировал(а) Gluttton - 1.5.2009, 20:35


--------------------
Слава Україні!
PM MAIL   Вверх
Keeper89
Дата 1.5.2009, 23:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Gluttton, спасибо.


--------------------
PM MAIL WWW   Вверх
Zloxa
Дата 2.5.2009, 00:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Gluttton @  1.5.2009,  19:26 Найти цитируемый пост)

В результате денормализации возникает избыточность, но и упрощается работа с БД (запросы составлять легче и выполняються они быстрее).

В одном месте упрощается, в другом усложняется. smile
С одной стороны легче извлекать данные, с другой стороны, тяжелее модифицировать и поддерживать ссылочную целостность. ;)

Цитата(Gluttton @  1.5.2009,  19:26 Найти цитируемый пост)
Но! 

Есть еще Но. Придется ФИО одного и того же автора вводить многожды. Когдато это будет "Пушкин А.С.", когда то "Пушкин АС", "Пушкин Алексадр Сергеевич", когдато "АС Плюшкин". Это усложнит отбор по автору.

ИМХО ответ очевиден, связь many to many - классика и реализуется через промежуточную таблицу.

Это сообщение отредактировал(а) Zloxa - 2.5.2009, 00:26


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

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

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

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

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


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

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

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

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

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


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

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


 




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


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

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