Проектирование реляционных баз данных на основе принципов нормализации. (Лекция 6)

Содержание

Слайд 2

проект реляционной базы данных Это набор взаимосвязанных отношений, в которых определены

проект реляционной базы данных

Это набор взаимосвязанных отношений, в которых
определены все

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

Уровни моделирования Сама предметная область Модель предметной области Логическая модель данных

Уровни моделирования

Сама предметная область Модель предметной области Логическая модель данных

Физическая модель данных Собственно база данных и приложения
Слайд 4

Критерии оценки качества логической модели данных Адекватность базы данных предметной области

Критерии оценки качества логической модели данных

Адекватность базы данных предметной области


Легкость разработки и сопровождения базы данных
Скорость выполнения операций обновления данных (вставка, обновление, удаление кортежей)
Скорость выполнения операций выборки данных
Слайд 5

Адекватность базы данных предметной области Состояние базы данных в каждый момент

Адекватность базы данных предметной области

Состояние базы данных в каждый момент времени

должно соответствовать состоянию предметной области.
Изменение состояния предметной области должно приводить к соответствующему изменению состояния базы данных
Ограничения предметной области, отраженные в модели предметной области, должны некоторым образом отражаться и учитываться базе данных.
Слайд 6

Легкость разработки и сопровождения базы данных Практически любая база данных, за

Легкость разработки и сопровождения базы данных

Практически любая база данных, за исключением

совершенно элементарных, содержит некоторое количество программного кода в виде триггеров и хранимых процедур.
Очевидно, что чем больше программного кода в виде триггеров и хранимых процедур содержит база данных, тем сложнее ее разработка и дальнейшее сопровождение.
Слайд 7

Скорость операций обновления данных (вставка, обновление, удаление) Основными операциями, изменяющими состояние

Скорость операций обновления данных (вставка, обновление, удаление)

Основными операциями, изменяющими состояние

базы данных, являются операции вставки, обновления и удаления записей.
скорость выполнения операций вставки, обновления и удаления также уменьшается при увеличении количества индексов у таблицы и мало зависит от числа строк в таблице.
Слайд 8

Скорость операций выборки данных Одной из наиболее дорогостоящих операций при выполнении

Скорость операций выборки данных

Одной из наиболее дорогостоящих операций при выполнении оператора

SELECT является операция соединение таблиц.
Таким образом, увеличение количества отношений приводит к замедлению выполнения операций выборки данных, особенно, если запросы заранее неизвестны.
Слайд 9

Результаты Исследования OASIG • Примерно 80-90% компьютеризованных систем не обладают требуемой

Результаты Исследования OASIG

• Примерно 80-90% компьютеризованных систем не обладают требуемой производительностью.

При разработке около 80% систем были превышены установленные для этого временные и бюджетные рамки.
• Разработка около 40% систем закончилась неудачно или была прекращена до завершения работы.
• Менее чем 40% систем предусматривали профессиональное обучение и повышение квалификации пользователей во всем необходимом объеме.
• Гармонично интегрировать интересы бизнеса и используемой технологии удалось не более чем в 25% систем.
• Только 10-20% систем отвечают всем критериям достижения успеха.
Слайд 10

Неудачи при создании программного обеспечения были вызваны следующими причинами: а отсутствием

Неудачи при создании программного обеспечения были вызваны следующими причинами:

а отсутствием полной спецификации

всех требований;
• отсутствием приемлемой методологии разработки;
• недостаточной степенью разделения общего глобального проекта на отдельные компоненты, поддающиеся эффективному контролю и управлению.
Слайд 11

Этапы разработки ИС Планирование разработки базы данных Определение требований к системе

Этапы разработки ИС

Планирование разработки базы данных
Определение требований к системе
Сбор и анализ

требований пользователей
Проектирование базы данных
Выбор целевой СУБД (необязательный этап)
Разработка приложений
Создание прототипов (необязательный этап)
Реализация
Преобразование и загрузка данных
Тестирование
Эксплуатация и сопровождение
Слайд 12

Модель предметной области Сотрудники организации выполняют проекты. Проекты состоят из нескольких

Модель предметной области

Сотрудники организации выполняют проекты.
Проекты состоят из нескольких

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

Ввод дополнительных аттрибутов О каждом сотруднике необходимо хранить табельный номер и

Ввод дополнительных аттрибутов

О каждом сотруднике необходимо хранить табельный номер и фамилию.

Табельный номер является уникальным для каждого сотрудника.
Каждый отдел имеет уникальный номер.
Каждый проект имеет номер и наименование. Номер проекта является уникальным.
Каждая работа из проекта имеет номер, уникальный в пределах проекта. Работы в разных проектах могут иметь одинаковые номера.
Слайд 14

Проектирование схемы БД Проектирование схемы БД может быть выполнено двумя путями:

Проектирование схемы БД

Проектирование схемы БД может быть выполнено двумя путями:
путем декомпозиции

(разбиения), когда исходное множество отношений, входящих в схему БД заменяется другим множеством отношений (число их при этом возрастает), являющихся проекциями исходных отношений;
путем синтеза, то есть путем компоновки из заданных исходных элементарных зависимостей между объектами предметной области схемы БД.
Слайд 15

Процесс проектирования с использованием декомпозиции Процесс проектирования с использованием декомпозиции представляет

Процесс проектирования с использованием декомпозиции

Процесс проектирования с использованием декомпозиции представляет собой

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

1НФ (Первая Нормальная Форма) В отношении нет одинаковых кортежей. Кортежи не

1НФ (Первая Нормальная Форма)

В отношении нет одинаковых кортежей.
Кортежи не упорядочены.


Атрибуты не упорядочены и различаются по наименованию.
Все значения атрибутов атомарны.
Слайд 17

Потенциальный ключ Потенциальным ключом отношения называется набор атрибутов отношения, кото­рый полностью

Потенциальный ключ

Потенциальным ключом отношения называется набор атрибутов отношения, кото­рый полностью и

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

СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ Н_СОТР - табельный номер сотрудника ФАМ - фамилия сотрудника Н_ОТД

СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ

Н_СОТР - табельный номер сотрудника
ФАМ - фамилия сотрудника
Н_ОТД

- номер отдела, в котором числится сотрудник
ТЕЛ - телефон сотрудника
Н_ПРО - номер проекта, над которым работает сотрудник
ПРОЕКТ - наименование проекта, над которым работает сотрудник
Н_ЗАДАН - номер задания, над которым работает сотрудник
Т.к. каждый сотрудник в каждом проекте выполняет ровно одно задание, то в качестве потенциального ключа отношения необходимо взять пару атрибутов {Н_СОТР, Н_ПРО}.
Слайд 19

Отношение

Отношение

Слайд 20

Аномалии обновления неадекватность модели данных предметной области, либо некоторые дополнительные трудности

Аномалии обновления

неадекватность модели данных предметной области, либо некоторые дополнительные трудности

в реализации ограничений предметной области
Аномалии вставки (INSERT)
Аномалии обновления (UPDATE)
Аномалии удаления (DELETE
Слайд 21

Аномалии вставки (INSERT) В отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ нельзя вставить данные о сотруднике,

Аномалии вставки (INSERT)

В отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ нельзя вставить данные о сотруднике,

который пока не участвует ни в одном проекте.
Точно также нельзя вставить данные о проекте, над которым пока не работает ни один сотрудник.
Причина аномалии - хранение в одном отношении разнородной информации (и о сотрудниках, и о проектах, и о работах по проекту).
Слайд 22

Аномалии обновления (UPDATE) если сотрудник меняет фамилию, или проект меняет наименование,

Аномалии обновления (UPDATE)

если сотрудник меняет фамилию, или проект меняет наименование, или

меняется номер телефона, то такие изменения необходимо одновременно выполнить во всех местах, где эта фамилия, наименование или номер телефона встречаются, иначе отношение станет некорректным.
Причина аномалии - избыточность данных, также порожденная тем, что в одном отношении хранится разнородная информация.
Слайд 23

Аномалии удаления (DELETE) При удалении некоторых данных может произойти потеря другой

Аномалии удаления (DELETE)

При удалении некоторых данных может произойти потеря другой информации.
Вывод

- логическая модель данных неадекватна модели предметной области. База данных, основанная на такой модели, будет работать неправильно.
Слайд 24

Определение функциональной зависимости

Определение функциональной зависимости

Слайд 25

примеры функциональных зависимостей: Зависимость атрибутов от ключа отношения {Н_СОТР, Н_ПРО} ФАМ

примеры функциональных зависимостей:

Зависимость атрибутов от ключа отношения
{Н_СОТР, Н_ПРО} ФАМ


{Н_СОТР, Н_ПРО} Н_ОТД
{Н_СОТР, Н_ПРО} ТЕЛ
{Н_СОТР, Н_ПРО} ПРОЕКТ
{Н_СОТР, Н_ПРО} Н_ЗАДАН
Зависимость атрибутов, характеризующих сотрудника от табельного номера сотрудника:
Н_СОТР ФАМ
Н_СОТР Н_ОТД
Н_СОТР ТЕЛ
Зависимость наименования проекта от номера проекта:
Н_ПРО ПРОЕКТ
Зависимость номера телефона от номера отдела:
Н_ОТД ТЕЛ
Слайд 26

Математическое определение

Математическое определение

Слайд 27

2НФ (Вторая Нормальная Форма) Определение 3. Отношение находится во второй нормальной

2НФ (Вторая Нормальная Форма)

Определение 3. Отношение находится во второй нормальной форме

(2НФ) тогда и только тогда, когда отношение находится в 1НФ и нет неключевых атрибутов, зависящих от части сложного ключа.
Неключевой атрибут - это атрибут, не входящий в состав никакого потенциального ключа.
Слайд 28

Пример Отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ не находится в 2НФ, т.к. есть атрибуты, зависящие

Пример

Отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ не находится в 2НФ, т.к. есть атрибуты, зависящие от

части сложного ключа:
Зависимость атрибутов, характеризующих сотрудника от табельного номера сотрудника является зависимостью от части сложного ключа:
Н_СОТР ФАМ
Н_СОТР Н_ОТД
Н_СОТР ТЕЛ
Зависимость наименования проекта от номера проекта является зависимостью от части сложного ключа:
Н_ПРО ПРОЕКТ
Слайд 29

Отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ декомпозируем на три отношения - СОТРУДНИКИ_ОТДЕЛЫ, ПРОЕКТЫ, ЗАДАНИЯ.

Отношение СОТРУДНИКИ_ОТДЕЛЫ_ПРОЕКТЫ декомпозируем на три отношения - СОТРУДНИКИ_ОТДЕЛЫ,
ПРОЕКТЫ,
ЗАДАНИЯ.

Слайд 30

Отношение СОТРУДНИКИ_ОТДЕЛЫ

Отношение СОТРУДНИКИ_ОТДЕЛЫ

Слайд 31

Отношение ПРОЕКТЫ и ЗАДАНИЯ

Отношение ПРОЕКТЫ и ЗАДАНИЯ

Слайд 32

Анализ декомпозированных отношений Отношения, полученные в результате декомпозиции, находятся в 2НФ.

Анализ декомпозированных отношений

Отношения, полученные в результате декомпозиции, находятся в 2НФ. СОТРУДНИКИ_ОТДЕЛЫ

и ПРОЕКТЫ имеют простые ключи, следовательно автоматически находятся в 2НФ
отношение ЗАДАНИЯ имеет сложный ключ, но единственный неключевой атрибут Н_ЗАДАН функционально зависит от всего ключа {Н_СОТР, Н_ПРО}.
Слайд 33

Оставшиеся аномалии вставки (INSERT) В отношение СОТРУДНИКИ_ОТДЕЛЫ нельзя вставить кортеж (4,

Оставшиеся аномалии вставки (INSERT)

В отношение СОТРУДНИКИ_ОТДЕЛЫ нельзя вставить кортеж (4, Пушников,

1, 33-22-11), т.к. при этом получится, что два сотрудника из 1-го отдела (Иванов и Пушников) имеют разные номера телефонов, а это противоречит модели предметной области.
Слайд 34

Оставшиеся аномалии удаления (DELETE) При удалении некоторых данных по-прежнему может произойти

Оставшиеся аномалии удаления (DELETE)

При удалении некоторых данных по-прежнему может произойти

потеря другой информации. Например, если удалить сотрудника Сидорова, то будет потеряна информация о том, что в отделе номер 2 находится телефон 33-22-11.
Слайд 35

3НФ (Третья Нормальная Форма) Определение 4. Атрибуты называются взаимно независимыми, если

3НФ (Третья Нормальная Форма)

Определение 4. Атрибуты называются взаимно независимыми, если ни

один из них не является функционально зависимым от другого.
Определение 5. Отношение находится в третьей нормальной форме (3НФ) тогда и только тогда, когда отношение находится в 2НФ и все неключевые атрибуты взаимно независимы.
Отношение СОТРУДНИКИ_ОТДЕЛЫ не находится в 3НФ, т.к. имеется функциональная зависимость неключевых атрибутов (зависимость номера телефона от номера отдела):
Н_ОТД ТЕЛ
Слайд 36

Пример Отношение СОТРУДНИКИ_ОТДЕЛЫ декомпозируем на два отношения - СОТРУДНИКИ, ОТДЕЛЫ.

Пример

Отношение СОТРУДНИКИ_ОТДЕЛЫ декомпозируем на два отношения - СОТРУДНИКИ, ОТДЕЛЫ.

Слайд 37

Слайд 38

Пример Рассмотрим отношение, моделирующее сдачу студентами текущей сессии. Струк­тура этого отношения

Пример

Рассмотрим отношение, моделирующее сдачу студентами текущей сессии. Струк­тура этого отношения определяется

следующим набором атрибутов:
(ФИО, Номер зач.кн, Группа, Дисциплина, Оценка)
Слайд 39

Приведение ко 2НФ Для приведения данного отношения ко второй нормальной форме

Приведение ко 2НФ

Для приведения данного отношения ко второй нормальной форме следует

разбить его на проекции, при этом должно быть соблюдено условие восстановления исходного отношения без потерь.
Такими проекциями могут быть два отношения
(ФИО, Номер зач.кн, Группа)
(Номер зач.кн, Дисциплина, Оценка)
Слайд 40

Приведение к 3НФ Рассмотрим отношение, связывающее студентов с группами, факультетами и

Приведение к 3НФ

Рассмотрим отношение, связывающее студентов с группами, факультетами и специальностями
(ФИО,

Номер зач.кн, Группа, Факультет, Специальность, Выпускающая кафедра)
Слайд 41

Функциональные зависимости Номер зач.кн. -> ФИО Номер зач.кн. -> Группа Номер

Функциональные зависимости

Номер зач.кн. -> ФИО
Номер зач.кн. -> Группа
Номер зач.кн.

-> Факультет
Номер зач.кн. -> Специальность
Номер зач.кн. -> Выпускающая кафедра
Группа -> Факультет
Группа -> Специальность
Группа -> Выпускающая кафедра
Выпускающая кафедра -> Факультет
Слайд 42

Декомпозиция И эти зависимости образуют транзитивные группы. Для того чтобы избежать

Декомпозиция

И эти зависимости образуют транзитивные группы. Для того чтобы избежать этого,

мы можем предложить следующий набор отношений
(Номер.зач.кн., ФИО, Специальность, Группа)
(Группа, Выпускающая кафедра)
(Выпускающая кафедра, Факультет)
Первичные ключи отношений выделены.
Слайд 43

Алгоритм нормализации Шаг 1 (Приведение к 1НФ). На первом шаге задается

Алгоритм нормализации

Шаг 1 (Приведение к 1НФ). На первом шаге задается одно

или несколько отношений, отображающих понятия предметной области.
По модели предметной области (не по внешнему виду полученных отношений!) выписываются обнаруженные функциональные зависимости.
Все отношения автоматически находятся в 1НФ.
Слайд 44

Шаг 2 (Приведение к 2НФ). Если в некоторых отношениях обнаружена зависимость

Шаг 2 (Приведение к 2НФ). Если в некоторых отношениях обнаружена зависимость

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

Слайд 46

Шаг 3 (Приведение к 3НФ). Если в некоторых отношениях обнаружена зависимость

Шаг 3 (Приведение к 3НФ). Если в некоторых отношениях обнаружена зависимость

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

Слайд 48

Анализ критериев для нормализованных и ненормализованных моделей данных

Анализ критериев для нормализованных и ненормализованных моделей данных

Слайд 49

Корректность процедуры нормализации - декомпозиция без потерь Определение. Проекция R[X] отношения

Корректность процедуры нормализации - декомпозиция без потерь

Определение. Проекция R[X] отношения

R на множество атрибутов X называется собственной, если множество атрибутов X является собственным подмножеством множества X атрибутов отношения R (т.е. множество атрибутов X не совпадает с множеством всех атрибутов отношения R ).
Определение. Собственные проекции R1 и R2 отношения R называются декомпозицией без потерь, если отношение R точно восстанавливается из них при помощи естественного соединения для любого состояния отношения R:
R1 JOIN R2 = R
Слайд 50

Пример декомпозиции с потерями

Пример декомпозиции с потерями

Слайд 51

Естественное соединение

Естественное соединение

Слайд 52

Теорема Хеза

Теорема Хеза

Слайд 53

доказательство

доказательство

Слайд 54

Инфологическое проектирование

Инфологическое проектирование

Слайд 55

Модель «сущность—связь» Основные понятия: Сущность, с помощью которой моделируется класс однотипных

Модель «сущность—связь»

Основные понятия:
Сущность, с помощью которой моделируется класс однотипных объектов.
Объект, которому

соответствует понятие сущности, имеет свой набор атрибутов — характеристик, определяющих свойства данного представителя класса.
Набор атрибутов, однозначно идентифицирующий конкретный экземпляр сущности, называют ключевым.
сущностями могут быть установлены связи - бинарные ассоциации, показывающие, каким образом сущности соотносятся или взаимодействуют между собой.
Слайд 56

Пример

Пример

Слайд 57

Обязательные и необязательные связи Связь любого из этих типов может быть

Обязательные и необязательные связи

Связь любого из этих типов может быть обязательной,

если в данной связи должен участвовать каждый экземпляр сущности, необязательной — если не каждый экземпляр сущности должен участвовать в данной связи. При этом связь может быть обязательной с одной стороны и необязательной с другой стороны.
Слайд 58

Обозначения

Обозначения

Слайд 59

Типы связей Связи делятся на три типа по множественности: один-к-одному (1:1),

Типы связей

Связи делятся на три типа по множественности:
один-к-одному (1:1),
один-ко-многим

(1:М),
многие-ко-многим (М:М).
Между двумя сущностями может быть задано сколько угодно связей с разными смысловыми нагрузками.
Слайд 60

принцип категоризации сущностей Подтип сущности -- сущности, каждая из которых может

принцип категоризации сущностей

Подтип сущности -- сущности, каждая из которых может иметь

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

супертип Сущность, на основе которой строятся подтипы, называется супертипом. Любой экземпляр

супертип

Сущность, на основе которой строятся подтипы, называется супертипом. Любой экземпляр супертипа

должен относиться к конкретному подтипу.
Слайд 62

Пример супертипа и подтипов

Пример супертипа и подтипов

Слайд 63

Результат проектирования В результате построения модели предметной области в виде набора

Результат проектирования

В результате построения модели предметной области в виде набора сущностей

и связей получаем связный граф. В полученном графе необходимо избегать цик­лических связей — они выявляют некорректность модели.
Слайд 64

Пример инфологического проектирования В качестве примера спроектируем инфологическую модель системы, предназначенной

Пример инфологического проектирования

В качестве примера спроектируем инфологическую модель системы, предназначенной для

хранения информации о книгах и областях знаний, представленных в библиотеке.
Разработку модели начнем с выделения основных сущностей.
Слайд 65

Пример ER-модели

Пример ER-модели

Слайд 66

Преобразование ER-модели в реляционную

Преобразование ER-модели в реляционную

Слайд 67

правила преобразования ER-модели в реляционную. 1. Каждой сущности ставится в соответствие

правила преобразования ER-модели в реляционную.

1. Каждой сущности ставится в соответствие отношение

реляционной модели данных.
2. Каждый атрибут сущности становится атрибутом соответствующего отношения.
Слайд 68

Преобразование ключей 4. В каждое отношение, соответствующее подчиненной сущности, добавляется набор

Преобразование ключей

4. В каждое отношение, соответствующее подчиненной сущности, добавляется набор атрибутов

основной сущности, являющейся первичным ключом основной сущности. В отношении, соответствующем подчиненной сущности, этот набор атрибутов становится внешним ключом (FOREING KEY).
Слайд 69

Связи 5. Для моделирования необязательного типа связи на физическом уровне у

Связи

5. Для моделирования необязательного типа связи на физическом уровне у атрибутов,

соответствующих внешнему ключу, устанавливается свойство допустимости неопределенных значений (признак NULL).
При обязательном типе связи атрибуты получают свойство отсутствия неопределенных значений (признак NOT NULL).
Слайд 70

Категоризация типов Для отражения Категоризации сущностей при переходе к реляционной модели

Категоризация типов

Для отражения Категоризации сущностей при переходе к реляционной модели возможны

несколько вариантов представления.
Возможно создать только одно отношение для всех подтипов одного супертипа
Слайд 71

При втором способе для каждого подтипа и для супертипа создаются свои

При втором способе для каждого подтипа и для супертипа создаются свои

отдельные отношения.
Для возможности переходов к подтипам от супертипа необходимо в супертип включить идентификатор связи.
Слайд 72

дискриминаторы Дополнительно при описании отношения между типом и подтипами необходимо указать

дискриминаторы

Дополнительно при описании отношения между типом и подтипами необходимо указать тип

дискриминатора
Дискриминатор может быть взаимоисключающим или нет
Слайд 73

Пример – наследование идентификатора суперсущности

Пример – наследование идентификатора суперсущности

Слайд 74

Наследование всех атрибутов суперсущности

Наследование всех атрибутов суперсущности

Слайд 75

Разрешение связей типа «многие-ко-многим». Это делается введением специального дополнительного связующего отношения,

Разрешение связей типа «многие-ко-многим».

Это делается введением специального дополнительного связующего отношения, которое

связано с каждым исходным связью «один-ко-многим», атрибутами этого отношения являются первичные ключи связываемых отношений.
например» в схеме «Библиотека» присутствует связь такого типа между сущностью «Книги» и «Системный каталог». Для разрешения этой неспецифической связи при переходе к реляционной модели, должно быть введено специальное дополнительное отношение, которое имеет всего два атрибута;
ISBN (шифр книги) и KOD (код области знаний).
При этом каждый из атрибутов нового отношения является внешним ключом (FORKING KEY), а вместе они образуют первичный ключ (PRIMARY KEY) повой связующей сущности.