Модель сущность-связь — различия между версиями
(→Ассоциации) |
(→Альтернативные нотации) |
||
| Строка 135: | Строка 135: | ||
== Альтернативные нотации == | == Альтернативные нотации == | ||
| + | Выше рассматривалась нотация '''Crow's foot''', предложенная Гордоном Эверестом. | ||
| + | ===Нотация Питера Чена=== | ||
| + | Модель Сущность-связь была предложена Питером Ченом в 1976 году, им же была предложена следующая графическая нотация: | ||
| + | |||
| + | [[Файл:Нотация Питера Чена.png|600px]] | ||
| + | |||
| + | ===UML-нотация=== | ||
| + | Для каждой таблицы явно подписывается, что она обозначает (ассоциацию, сущность и т.д.). Ограничения прописываются в виде $i..k$ (например, $1..n$), это позволяет наложить ограничение $2..n$, что было невозможно в Crow's foot. | ||
| + | |||
| + | [[Файл:UML-нотация.png|400px]] | ||
| + | |||
| + | ===Object Definition Language=== | ||
| + | |||
| + | '''class''' Student { | ||
| + | int Id; | ||
| + | string Name; | ||
| + | Group group inverse Group::Students; | ||
| + | } | ||
| + | |||
| + | '''class''' Group { | ||
| + | int id; | ||
| + | Set<Student> students inverse Student::group; | ||
| + | } | ||
Версия 13:14, 27 декабря 2020
Содержание
Сущности
| Определение: |
| Сущностью (англ. entity) называют некоторый объект, обладающий именем и атрибутами. |
| Определение: |
| Атрибутом (англ. attribute) называют некоторую характеристику объекта, содержащую имя атрибута и домен и обладающую некоторыми свойствами. |
Домен не указывает конкретный физический тип, однако позволяет указать, какие атрибуты будут иметь одинаковый тип в физической модели. Так, например, атрибуты $FirstName$ и $LastName$ сущности $Student$ будут обладать одним физическим типом.
Типы доменов:
- Простой — атомарное значение, например, $id$
- Составной — состоящий из нескольких значений, например,
passport { series: char(4), number: char(6) }
Свойства атрибутов:
| Обозначение | Свойство |
|---|---|
| M | Обязательное (англ. mandatory) |
| O | Необязательное (англ. optional) |
| PK | Основной ключ (англ. primary key) |
| Kn | Дополнительный ключ $n$ (англ. key) |
Связи
Связь обозначается линией с двумя концами и обладает следующими характеристиками:
- Имя
- Связываемые сущности и их роли
- Тип связи (задается типами концов)
На примере показано, что студен принадлежит одной группе, а в группе может быть несколько студентов (в том числе нуль).
Типы концов:
| Тип | Обозначение |
|---|---|
| Один | |
| Много | |
| Обязательный | |
| Необязательный |
Можно выбрать значение по умолчанию, которое будет обозначаться сплошной линией без символов.
Примеры:
| Связь | Значение | По умолчанию |
|---|---|---|
| Многие ко многим | Единственность, необязательность | |
| Один ко многим | Единственность, обязательность | |
| Один к одному | Единственность, обязательность |
Ассоциации
| Определение: |
| Ассоциацией (англ. association) называется многосторонняя связь, нагруженная произвольными не ключевыми атрибутами. |
Замечания:
- Ассоциация обозначается прямоугольником с закругленными краями
- Может содержать не ключевые атрибуты
- Имеет произвольное количество концов с произвольными ролями и типами
Проанализируем пример. Контракт заключается с одним студентом, на одну специальность, которая может быть не указана на момент заключения контракта. У контракта должен быть один или более поручителей. Контракт нагружен информацией о датах, когда контракт был подготовлен (обязательный атрибут) и подписан (опциональный атрибут, поскольку контракт может быть подписан не сразу).
Как понять, что использовать: ассоциацию, связь или сущность?
- Если нужно два конца и нет нагруженности, используем связь
- Если нужно идентифицировать, используем сущность, поскольку связь не идентифицируется из-за отсутствия ключевых элементов
- Иначе используется ассоциация
Многосторонние ассоциации
Многостороннюю ассоциацию можно интерпретировать по-разному. Так, например, на рисунке может быть обозначено следующее:
- У каждого контракта есть один поручитель
- Можно быть поручителем у ровно одного контракта
Также существуют обобщенные ограничения (англ. generic), позволяющие зафиксировать произвольное подмножество.
Слабые сущности
| Определение: |
| Слабой сущностью называется сущность, у которой недостаточно атрибутов для идентификации. |
Слабая сущность обозначается двойным прямоугольником.
| Определение: |
| Идентифицирующей связью называется связь, позволяющая слабой сущности получить атрибуты, необходимые для ее идентификации. |
Идентифицирующая связь обозначается двойной сплошной линией.
Например, название учебной группы уникально в рамках одного университета. Если же мы будем рассматривать несколько университетов, для идентификации группы будет недостаточно лишь ее названия. В таком случае можно считать группу слабой сущностью, для идентификации которой необходим университет.
Альтернативные нотации
Выше рассматривалась нотация Crow's foot, предложенная Гордоном Эверестом.
Нотация Питера Чена
Модель Сущность-связь была предложена Питером Ченом в 1976 году, им же была предложена следующая графическая нотация:
UML-нотация
Для каждой таблицы явно подписывается, что она обозначает (ассоциацию, сущность и т.д.). Ограничения прописываются в виде $i..k$ (например, $1..n$), это позволяет наложить ограничение $2..n$, что было невозможно в Crow's foot.
Object Definition Language
class Student {
int Id;
string Name;
Group group inverse Group::Students;
}
class Group {
int id;
Set<Student> students inverse Student::group;
}