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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Нормальизация БД 
:(
    Опции темы
QVO
Дата 3.11.2014, 10:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Здравствуйте форумчани!

Описание:
Помогите разобраться в правильности понимания материала из книги "К.ДЖ.Дейт - Введение в базы данных". Я стараюсь спроектировать БД согласно 3 правилам нормализации (1НФ, 2НФ, 3НФ).
У меня есть сущность Service, которая содержит множество изображений из сущности Preview, а так же есть сущность Skin, которая так же содержит множество изображение из сущности Preview.
Для того, чтобы связать эти 3 сущности между собой, я создал две дополнительные с названием Skin_has_Preview и Service_has_Preview, которые содержат ссылки на предыдущие 3 таблицы.

Skin_has_Preview связан с Preview один-к-одному
Service_has_Preview связан с Preview один-к-одному

Skin связан с Skin_has_Preview многое-к-одному
Service связан с Service_has_Preview многое-к-одному

К прикрепленным файлам я приложил изображение ER-диаграммы.

Вопросы:
1. Правильно ли я сделал?
2. Могули я в таблицах Skin_has_Preview и Service_has_Preview иметь первичный ключь ссылающийся на первичный ключь сущности Preview?

Если не понятно изложился, задайте пожалуйста уточняющий вопрос.

user posted image
PM MAIL ICQ Skype   Вверх
QVO
Дата 4.11.2014, 11:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Вопрос снимаю.

Ответ:
Если связь типа 1:М и класс принадлежности сущности на стороне М  является необязательным, то необходимо построить три таблицы – по одной для каждой сущности и одну для связи. Первичный ключ сущности  должен быть первичным ключом соответствующей таблицы. Таблица для связи среди своих атрибутов должна иметь ключи обеих сущностей.

Это сообщение отредактировал(а) QVO - 4.11.2014, 11:53
PM MAIL ICQ Skype   Вверх
Akina
Дата 4.11.2014, 22:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


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

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



Цитата(QVO @  4.11.2014,  12:50 Найти цитируемый пост)
Если связь типа 1:М и класс принадлежности сущности на стороне М  является необязательным, то необходимо построить три таблицы – по одной для каждой сущности и одну для связи. 

Для связи 1:М двух таблиц достаточно. Вне зависимости от обязательности записи на стороне Много. Вот в случае N:M - да, три таблицы.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

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

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

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

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

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


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

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

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

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

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


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

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


 




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


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

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