Методические указания По выполнению курсовой работы Для обучающихся по направлению
Download 438.33 Kb.
|
Ислом курсовой 2
|
(бЫ |
рЫ |
<№) |
Б1 |
Р1 |
100 |
Б1 |
Р2 |
100 |
Б2 |
Р1 |
200 |
Б2 |
РЗ |
200 |
БЗ |
Р1 |
100 |
Из приведенной реализации можно сделать вывод, что 51<3 ->
Но в какой-то следующий момент времени в реализации отношения может появиться кортеж <81, РЗ, 200>, который нарушает предполагаемую функциональную зависимость.
Как определять функциональные зависимости
Декларация функциональных зависимостей — решение, которое может быть принято только проектировщиком на основе анализа семантики атрибутов. Функциональные зависимости не могут быть доказаны, но они будут претворяться в жизнь средствами СУБД, если ей это предписано (это определяется установленными ограничениями целостности).
На что влияют функциональные зависимости
1. Функциональные зависимости гарантируют, что СУБД в дальнейшем будет поддерживать определенные ими ограничения целостности.
2. Возможно, обеспечат более эффективную реализацию отношения.
3. Но! Делают невозможным хранение некоторой информации.
Рассмотрим пример, иллюстрирующий важность определения
функциональных зависимостей. Пусть, например, определена следующая схема отношения:
ОТДЕЛ (Название. Номер помещения, Телефон).
Очевидно, что такая схема отношения определяет функциональную зависимость Название -> Телефон. Возможная реализация отношения:
ОТДЕЛ (Название Номер помещения Телефон)
Бухгалтерия 128 123-4567
• • • ••• •••
Это означает, что никакой отдел не может иметь несколько телефонов.
Еще один пример. Уже говорилось, что в любом отношении есть функциональная зависимость РК -Э Я. Если для некоторой схемы Я кроме указанной функциональной зависимости существуют еще и другие типа А -Э В, то, вообще говоря, схема отношения Я будет характеризоваться некоторой избыточностью. Действительно, рассмотрим следующую схему отношения:
ПОСТАВЩИК (Номер поставщика. Имя, Город, Код города).
В этой схеме определена функциональная зависимость
Город -> Код города.
Следовательно, в каждом кортеже для каждого значения атрибута Город будет повторяться соответствующее значение атрибута Код города.
Чем это плохо?
Функциональные зависимости определяют некоторые ограничения целостности, которые должны проверяться при каждом обновлении состояния базы данных. Если таких ограничений много — слишком много времени будет тратиться на их проверку, что конечно же не очень хорошо. Например, если в некоторой реализации приведенного выше отношения ПОСТАВЩИК несколько десятков (или более) кортежей имеют одно и то же значение атрибута Город (например, Москва) и поменялся код этого города, необходимо внести изменения во все кортежи отношения.
Таким образом, функциональные зависимости рассматриваются как средство задания ограничений целостности для схемы отношения Я, и они будут проверяться.
3>
Download 438.33 Kb.
Do'stlaringiz bilan baham:
Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling
ma'muriyatiga murojaat qiling