Ver código fonte

пример erd в workbench

Евгений Колесников 4 anos atrás
pai
commit
9cfd9fa7c9
12 arquivos alterados com 127 adições e 0 exclusões
  1. 125 0
      articles/5_1_1_1_erd_workbench.md
  2. BIN
      img/01012.png
  3. BIN
      img/01013.png
  4. BIN
      img/01014.png
  5. BIN
      img/01015.png
  6. BIN
      img/01016.png
  7. BIN
      img/01017.png
  8. BIN
      img/01018.png
  9. BIN
      img/01019.png
  10. BIN
      img/01020.png
  11. BIN
      img/01021.png
  12. 2 0
      readme.md

+ 125 - 0
articles/5_1_1_1_erd_workbench.md

@@ -0,0 +1,125 @@
+[содержание](/readme.md)
+
+# Создание ER-диаграммы в среде MySQL Workbench
+
+## Предметная область
+
+Давайте теперь поработаем с системой базы данных *MyFlix Video Library*, чтобы помочь понять концепцию ER-диаграмм. Мы будем использовать эту базу данных для всей практической работы в оставшейся части этого урока
+
+MyFlix — это юридическое лицо, которое сдает в аренду фильмы своим членам. MyFlix хранит свои записи вручную. Теперь руководство хочет перейти на СУБД
+
+Вспомним шаги по разработке диаграммы EER для базы данных:
+
+* Определить сущности и отношения, которые существуют между ними.
+* Каждая сущность, атрибут и отношение должны иметь соответствующие имена, которые могут быть легко понятны и нетехническим людям.
+* Отношения не должны быть связаны напрямую друг с другом. Отношения должны соединять сущности.
+* Каждый атрибут в данном объекте должен иметь уникальное имя.
+
+### Объекты, которые должны быть включены в нашу ER-диаграмму:
+
+**Участники** — эта сущность будет хранить информацию об участниках.
+
+**Фильмы** — эта сущность будет содержать информацию о фильмах
+
+**Категории** — эта сущность будет содержать информацию, которая помещает фильмы в различные категории, такие как «Драма», «Действие», «Эпический» и т. Д.
+
+**Прокат фильмов** — эта сущность будет хранить информацию о фильмах, сдаваемых в аренду ее членам.
+
+**Платежи** — эта сущность будет хранить информацию о платежах, произведенных участниками.
+
+### Определение отношений между сущностями
+
+**Участники и фильмы**
+
+* **Участник** может арендовать один или больше фильмов.
+* **Фильм** может быть арендован более чем одним участником.
+
+Из приведенного выше сценария мы можем видеть, что нужно использовать отношение «многие ко многим». Реляционные базы данных не поддерживают отношения «многие ко многим». Нам нужно ввести новую сущность - таблицу связей. Эту роль будет играет таблица MovieRentals. Она имеет отношение один-ко-многим с таблицей участников и отношение один-ко-многим с таблицей фильмов.
+
+**Фильмы и категории лиц**
+
+* **Фильм** может принадлежать только к одной категории, но в **категории** может быть несколько фильмов.
+
+Из этого можно сделать вывод, что характер отношений между категориями и таблицей фильмов один-ко-многим.
+
+**Участники и платежные организации**
+
+* **Участник** может иметь только одну учетную запись, но может сделать несколько **платежей**.
+
+Из этого можно сделать вывод, что характер взаимоотношений между участниками и платежными организациями один-ко-многим.
+
+## Теперь давайте создадим модель EER, используя MySQL Workbench
+
+>Модель улучшенного отношения сущностей (EER)
+>
+>Модель Enhanced Entity Relationship (EER) — это модель данных высокого уровня, которая предоставляет расширения для исходной модели Entity Relationship (ER). EER Models поддерживает более детальный дизайн. EER Modeling появилась как решение для моделирования очень сложных баз данных.
+
+В рабочей среде *MySQL Workbench* перейдите в режим моделирования и нажмите кнопку «+»
+
+![](../img/01012.png)
+
+Дважды щелкните кнопку *Добавить диаграмму*, чтобы открыть рабочее пространство для диаграмм ER.
+
+![](../img/01013.png)
+
+Появляется окно *EER Diagram*
+
+![](../img/01014.png)
+
+Давайте посмотрим на два типа объектов, с которыми мы будем работать.
+
+* Объект таблицы позволяет нам создавать объекты и определять атрибуты, связанные с конкретным объектом.
+* Кнопки отношений позволяет нам определять отношения между объектами.
+
+**Участники** организации будет иметь следующие атрибуты
+
+* Членский номер
+* Полные имена
+* Пол
+* Дата рождения
+* Физический адрес
+* Почтовый адрес
+
+### Создадим таблицу участников:
+
+1. Кликните по кнопке "Таблица"
+
+    В верхней части окна диаграммы появится запрос параметров для создаваемой таблицы:
+
+    ![](../img/01015.png)
+
+    Выбираем **utf8_unicode_ci** и кликаем по области диаграммы - появится сущность с названием *table1*
+
+2. Дважды кликните мышкой по этой сущности. Появится окно свойств, показанное ниже:
+
+    ![](../img/01016.png)
+
+3. Задайте название сущности (поле **Table Name**) и добавьте атрибуты (**Column Name**)
+
+    Должно получиться примерно такое:
+
+    ![](../img/01018.png)
+
+Повторите эти действия для всех сущностей, в итоге должно получиться примерно так:
+
+![](../img/01017.png)
+
+Обратите внимание:
+
+* Таблица связей названа по именам связываемых сущностей
+* В названиях сущностей и атрибутов используем CamelCase и единственное число
+* сразу создаем атрибуты для связей (PaymentId, MemberId, MovieId? CategoryId). В принципе *MySQL Workbench* может автоматически созавать эти атрибуты при создании связей, но при этом он называет их не по нашему стандарту.
+
+### Создадим связи
+
+1. Кликаем по иконке создания связи "один-ко-многим"
+
+    ![](../img/01019.png)
+
+2. Затем последовательно кликаем по внешнему ключу MemberMovie.MemberId и Member.id (нужные поля подсвечиваются под курсором)
+
+    ![](../img/01020.png)
+
+Повторяем эти действия для всех связей, в итоге получится примерно следующее:    
+
+![](../img/01021.png)

BIN
img/01012.png


BIN
img/01013.png


BIN
img/01014.png


BIN
img/01015.png


BIN
img/01016.png


BIN
img/01017.png


BIN
img/01018.png


BIN
img/01019.png


BIN
img/01020.png


BIN
img/01021.png


+ 2 - 0
readme.md

@@ -81,6 +81,8 @@ http://sergeyteplyakov.blogspot.com/2014/01/microsoft-fakes-state-verification.h
 
 2. [Основы проектирования баз данных.](articles/5_1_1_1_erd2.md)
 
+3. [Создание ER-диаграммы в среде MySQL Workbench](articles/5_1_1_1_erd_workbench.md)
+
 <!--
 2. [Жизненный цикл информационных систем.](articles/5_1_1_2_lifecycle.md)