Наследование

Ключи

 

Ключ или возможный ключ – это минимальный набор атрибутов, по значениям которых можно однозначно найти требуемый экземпляр объектного множества. Минимальность означает, что исключение из набора любого атрибута не позволяет идентифицировать элемент объектного множества по значениям оставшихся атрибутов. Каждое объектное множество обладает хотя бы одним возможным ключом. Один из них принимается за первичный ключ. При выборе первичного ключа следует отдавать предпочтение несоставным ключам.

Составной ключ – ключ, содержащий более одного атрибута.

Нецелесообразно также использовать ключи с длинными текстовыми значениями (предпочтительнее использовать целочисленные атрибуты). Так, для идентификации студента можно использовать либо уникальный номер зачетной книжки, либо набор из фамилии, имени, отчества, номера группы и может быть дополнительных атрибутов, так как не исключено появление в группе двух студентов с одинаковыми фамилиями, именами и отчествами.

Не допускается, чтобы первичный ключ (любой атрибут, участвующий в первичном ключе) принимал неопределенное значение. Иначе возникнет противоречивая ситуация, когда появится не обладающий индивидуальностью экземпляр объектного множества. По тем же причинам необходимо обеспечить уникальность первичного ключа.

Внешние ключи предназначены для установления связей между объектными множествами. Например, если объектное множество С связывает между собой объектные множества А и В, то оно должно включать внешние ключи, соответствующие первичным ключам сущностей А и В.

Элементы объектных множеств часто могут быть представлены внутренними номерами, которые не имеют смысла вне системы. Внутренний номер часто называют идентификатором объекта или суррогатным ключом, так как он однозначно определяет объект реального мира. Суррогатные ключи целесообразно использовать в следующих случаях:

· естественный атрибут должен играть роль ключа, но не обладает необходимым свойством уникальности;

· выбранный в качестве внешнего ключа атрибут имеет большую длину (например, длинная строка символов). Чтобы избежать его многократного дублирования, целесообразно присвоить ему код;

· естественный атрибут может менять свое значение со временем, например, название предприятия или фамилия сотрудника.

Ключ нужен не для каждого объекта. Например, в базе данных, записывающей продажи, пользователя может интересовать только продаваемый товар и объем продаж. В этом случае нет смысла создавать однозначный ключ для каждой продажи.

 

 

Если объект является конкретизацией другого объекта, то конкретизированный объект наследует все атрибуты и отношения обобщенного объекта. ЖЕНАТЫЙ МУЖЧИНА является конкретизацией объекта МУЖЧИНА. Поэтому у состоящего в браке человека есть имя, адрес и т.д. просто потому, что он является человеком. Объект ЖЕНАТЫЙ МУЖЧИНА наследует эти атрибуты от объекта МУЖЧИНА. Кроме того, у конкретизированного человека могут быть свои собственные атрибуты. Например, СУПРУГА будет атрибутом объекта ЖЕНАТЫЙ МУЖЧИНА, но не объекта МУЖЧИНА. Этот пример иллюстрируется рисунком 2.9.

Конкретизированные объекты наследуют не только атрибуты, но и все отношения.

Рисунок 2.9 - Наследование атрибутов при конкретизации