Разработка баз данных

Содержание

Слайд 2

Online-edu.mirea.ru

ТЕМА МОДЕЛИРОВАНИЕ ДАННЫХ

Online-edu.mirea.ru ТЕМА МОДЕЛИРОВАНИЕ ДАННЫХ

Слайд 3

План лекции

Логическое моделирование данных:
метод Баркера;
метод IDEF1X;
Подход, используемый в САSЕ-средстве Silverrun.
Алгоритм перехода от

План лекции Логическое моделирование данных: метод Баркера; метод IDEF1X; Подход, используемый в
ER–модели к реляционной схеме данных.
Физическое проектирование баз данных.

Слайд 4

Моделирование данных

Цель моделирования данных - обеспечение разработчика ИС концептуальной схемой базы данных

Моделирование данных Цель моделирования данных - обеспечение разработчика ИС концептуальной схемой базы
в форме одной или нескольких локальных моделей, которые могут быть отображены в любую систему баз данных.
Средство моделирования данных - диаграммы "сущность-связь".
Базовые понятия диаграммы «сущность-связь» (ERD):
Сущность (Entiry) - реальный либо воображаемый объект, имеющий существенное значение для рассматриваемой предметной области.
Связь (Relationship) - поименованная ассоциация между двумя сущностями, значимая для предметной области, при которой каждый экземпляр одной сущности ассоциирован с произвольным (в том числе нулевым) количеством экземпляров второй сущности, и наоборот.
Атрибут (Attriбute) - любая характеристика сущности, значимая для предметной области и предназначенная для квалификации, идентификации, классификации, количественной характеристики или выражения состояния сущности.

Слайд 5

Моделирование данных

Свойства сущности:
иметь уникальное имя:
к одному и тому же имени должна

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

Слайд 6

Метод Баркера

Первый шаг моделирования - извлечение информации из интервью и выделение сущностей.

Метод Баркера Первый шаг моделирования - извлечение информации из интервью и выделение

Графическое изображение сущности

Выделение сущностей

Слайд 7

Метод Баркера

Второй шаг моделирования - идентификация связей.

Графическое изображение степени и обязательности связи

Графическое

Метод Баркера Второй шаг моделирования - идентификация связей. Графическое изображение степени и
изображение - связь продавца с контрактом

Слайд 8

Метод Баркера

Диаграмма «сущность-связь» без атрибутов

Метод Баркера Диаграмма «сущность-связь» без атрибутов

Слайд 9

Метод Баркера

Третий шаг моделирования - идентификация атрибутов.

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

Метод Баркера Третий шаг моделирования - идентификация атрибутов. Графическое изображение атрибутов: обязательный
необязательный (помечен кружком)

Виды идентификации:
а - полная идентификация;
б- идентификация посредством другой сущности

Слайд 10

Метод Баркера

Диаграмма «сущность-связь» с атрибутами

Метод Баркера Диаграмма «сущность-связь» с атрибутами

Слайд 11

Метод Баркера

Супертипы и подтипы: одна сущность является обобщающим понятием для группы подобных

Метод Баркера Супертипы и подтипы: одна сущность является обобщающим понятием для группы подобных сущностей
сущностей

Слайд 12

Метод Баркера

Взаимно исключающие связи: каждый экземпляр сущности участвует только в одной связи

Метод Баркера Взаимно исключающие связи: каждый экземпляр сущности участвует только в одной
из группы взаимно исключающих связей

Рекурсивная связь: сущность может быть связана сама с собой

Неперемещаемые (non-transferrable) связи: экземпляр сущности не может быть перенесен из одного экземпляра связи в другой

Слайд 13

Метод IDEF1X

Метод IDEF1X основан на подходе Чена, позволяет построить модель данных, эквивалентную

Метод IDEF1X Метод IDEF1X основан на подходе Чена, позволяет построить модель данных,
реляционной модели в третьей нормальной форме.

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

Независимые (а) и зависимые (б) от идентификатора сущности

Слайд 14

Метод IDEF1X

Степень/мощность связи - количество экземпляров сущности-потомка, которое может существовать для каждого

Метод IDEF1X Степень/мощность связи - количество экземпляров сущности-потомка, которое может существовать для
экземпляра сущности-родителя.
Мощность связи может принимать следующие значения:
N - ноль, один или более,
Z - ноль или один,
Р - один или более,
фиксированное число.
По умолчанию мощность связи принимается равной N:

Слайд 15

Метод IDEF1X

Идентифицирующая связь - если экземпляр сущности-потомка однозначно определяется своей связью с

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

Идентифицирующая связь

Слайд 16

Метод IDEF1X

Неидентифицирующая связь - если экземпляр сущности-потомка не определяется однозначно своей связью

Метод IDEF1X Неидентифицирующая связь - если экземпляр сущности-потомка не определяется однозначно своей
с сущностью-родителем

Неидентифицирующая связь

Слайд 17

Подход, используемый в САSЕ-средстве Silverrun

Вариант нотации Чена используется для концептуального моделирования данных

Подход, используемый в САSЕ-средстве Silverrun Вариант нотации Чена используется для концептуального моделирования
на стадии формирования требований


ERD-диаграмма

Слайд 18

Подход, используемый в САSЕ-средстве Silverrun

Графическое представление сущности

Подход, используемый в САSЕ-средстве Silverrun Графическое представление сущности

Слайд 19

Подход, используемый в САSЕ-средстве Silverrun

Виды идентификаторов:
• первичный/альтернативный:
Первичный (основной) идентификатор – один, на диаграмме

Подход, используемый в САSЕ-средстве Silverrun Виды идентификаторов: • первичный/альтернативный: Первичный (основной) идентификатор
подчеркивается.
Альтернативные идентификаторы предваряются символами <1> для первого альтернативного идентификатора, <2> для второго и т. д.
• простой/составной: идентификатор, состоящий из одного атрибута, является простым, из нескольких атрибутов - составным;

Альтернативные идентификаторы

Слайд 20

Подход, используемый в САSЕ-средстве Silverrun

Виды идентификаторов:
• абсолютный/относительный:
– абсолютный идентификатор - если все атрибуты,

Подход, используемый в САSЕ-средстве Silverrun Виды идентификаторов: • абсолютный/относительный: – абсолютный идентификатор
составляющие идентификатор, принадлежат сущности;
– относительный идентификатор - если один или более атрибутов идентификатора принадлежат другой сущности.

Относительный идентификатор

Слайд 21

Подход, используемый в САSЕ-средстве Silverrun

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

Подход, используемый в САSЕ-средстве Silverrun Атрибуты связи Связь между сущностями в концептуальной
является типом, который представляет множество экземпляров связи между экземплярами сущностей.

Идентификатор связи

Слайд 22

Подход, используемый в САSЕ-средстве Silverrun

Атрибуты связи
Связь "супертип - подтип" - общие атрибуты

Подход, используемый в САSЕ-средстве Silverrun Атрибуты связи Связь "супертип - подтип" -
типа определяются в сущности - супертипе, сущность-подтип наследует все атрибуты супертипа

Связь "супертип-подтип"

Слайд 23

Алгоритм перехода от ER–модели к реляционной схеме данных

Шаг 1. Каждая простая сущность

Алгоритм перехода от ER–модели к реляционной схеме данных Шаг 1. Каждая простая
превращается в таблицу. Имя сущности становится именем таблицы.
Шаг 2. Каждый атрибут становится возможным столбцом с тем же именем. Столбцы, соответствующие необязательным атрибутам, могут содержать неопределенные значения; столбцы, соответствующие обязательным атрибутам, - не могут.
Шаг 3. Компоненты уникального идентификатора сущности превращаются в первичный ключ таблицы. Если в состав уникального идентификатора входят связи, к числу столбцов первичного ключа добавляется копия уникального идентификатора сущности, находящейся на дальнем конце связи.

Слайд 24

Алгоритм перехода от ER–модели к реляционной схеме данных

Шаг 4. Связи многие-к-одному и

Алгоритм перехода от ER–модели к реляционной схеме данных Шаг 4. Связи многие-к-одному
один-к-одному становятся внешними ключами. Необязательные связи соответствуют столбцам, допускающим неопределенные значения; обязательные связи - столбцам, не допускающим неопределенные значения.
Шаг 5. Индексы создаются для первичного ключа (уникальный индекс), внешних ключей и тех атрибутов, на которых предполагается базировать запросы.
Шаг 6. Если в концептуальной схеме присутствовали подтипы, то возможны два способа:
• все подтипы в одной таблице (а);
• для каждого подтипа - отдельная таблица (б) .

Слайд 25

Алгоритм перехода от ER–модели к реляционной схеме данных

Алгоритм перехода от ER–модели к реляционной схеме данных

Слайд 26

Алгоритм перехода от ER–модели к реляционной схеме данных

Шаг 7. Имеется два способа

Алгоритм перехода от ER–модели к реляционной схеме данных Шаг 7. Имеется два
работы при наличии исключающих связей:
• общий домен (а)
• явные внешние ключи (б)
Если остающиеся внешние ключи все в одном домене (способ (а)) - создаются два столбца:
идентификатор связи
и идентификатор сущности.
Если результирующие внешние ключи не относятся к одному домену - для каждой связи создаются явные столбцы внешних ключей.

Слайд 27

Online-edu.mirea.ru

ФИЗИЧЕСКОЕ ПРОЕКТИРОВАНИЕ БАЗ ДАННЫХ

Online-edu.mirea.ru ФИЗИЧЕСКОЕ ПРОЕКТИРОВАНИЕ БАЗ ДАННЫХ

Слайд 28

Особенности построения физической модели базы данных

Проблемы проектирования базы данных
Проблема логического проектирования

Особенности построения физической модели базы данных Проблемы проектирования базы данных Проблема логического
баз данных: Каким образом отобразить объекты предметной области в абстрактные объекты модели данных?
Проблема физического проектирования баз данных: Как обеспечить эффективность выполнения запросов к базе данных?

Физический уровень –отображение логической модели на модель данных конкретной СУБД.

Физическое проектирование - преобразование логической схемы с учетом синтаксиса, семантики и возможностей выбранной целевой СУБД.

Слайд 29

Особенности построения физической модели базы данных

Основные определения элементов физической модели

Физический тип данных

Особенности построения физической модели базы данных Основные определения элементов физической модели Физический
– тип данных, характеризующий столбец с данными.
Уникальный индекс первичного ключа – индекс, передающий столбцу в таблице все свойства первичного ключа.
Хранимая процедура - объект базы данных, представляющий собой набор SQL-инструкций, который компилируется один раз и хранится на сервере.
Триггер – хранимая процедура, запускаемая СУБД автоматически, при наступлении определенного в коде хранимой процедуры события.
Внешний ключ – подмножество столбцов некоторой переменной таблицы R2, значения которых должны совпадать со значениями некоторого первичного ключа некоторой переменной таблицы R1.

Слайд 30

Особенности построения физической модели базы данных

Термины физической модели

Особенности построения физической модели базы данных Термины физической модели

Слайд 31

Особенности построения физической модели базы данных

Этапы физического проектирования баз данных

Проектирование таблиц базы

Особенности построения физической модели базы данных Этапы физического проектирования баз данных Проектирование
данных с учетом специфики выбранной СУБД.
Реализация бизнес-правил в выбранной СУБД.
Дальнейшая оптимизация физической модели базы данных.
Разработка стратегии обеспечения безопасности информации.
Осуществление постоянного мониторинга базы данных и СУБД.

Слайд 32

Особенности построения физической модели базы данных

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

Денормализация – снижение

Особенности построения физической модели базы данных Анализ необходимости введения контролируемой избыточности Денормализация
требований к уровню нормализации отношений.

Виды денормализации, повышающие производительность системы

Использование производных данных:
дополнительная стоимость хранения производных данных и поддержки согласованности с текущими значениями исходных данных;
издержки на выполнение вычислений значений производных атрибутов при каждом обращении к ним.
Дублирование атрибутов.

Слайд 33

Особенности построения физической модели базы данных

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

Дублирование атрибутов
2.1. Объединение

Особенности построения физической модели базы данных Анализ необходимости введения контролируемой избыточности Дублирование
отношений, связанных 1:1.

Иерархия наследования
(неполная категория)

Иерархия наследования
(полная категория)

Слайд 34

Особенности построения физической модели базы данных

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

Дублирование атрибутов
2.2. Дублирование

Особенности построения физической модели базы данных Анализ необходимости введения контролируемой избыточности Дублирование
атрибутов в связях типа 1:M:
возможность включения атрибута одной таблицы в другую таблицу.
2.3. Использование служебных таблиц:
- значительно снижается вероятность ошибки при указании значений для атрибутов;
- уменьшается размер исходной таблицы;
- при изменении описания параметра значительно проще изменить одно значение в служебной таблице, чем корректировать множество записей в исходной.
2.4. Введение повторяющихся (многозначных) атрибутов.
2.5. Создание сводных таблиц.

Слайд 35

Особенности построения физической модели базы данных

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

Особенности построения физической модели базы данных Перенос логической схемы данных в среду
СУБД

Проектирование таблиц и связей.
Задание:
доменов;
первичных, альтернативных и внешних ключей;
неопределенных (NULL) и обязательных (NOT NULL) значений;
значений по умолчанию (DEFAULT);
правил контроля целостности;
хранимых процедур и триггеров.
Модификация логической схемы с учетом семантики и синтаксиса, принятой в целевой СУБД.

Слайд 36

Особенности построения физической модели базы данных

Логическая модель данных системы
"Реализация средств вычислительной

Особенности построения физической модели базы данных Логическая модель данных системы "Реализация средств вычислительной техники"
техники"

Слайд 37

Особенности построения физической модели базы данных

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

Особенности построения физической модели базы данных Перенос логической схемы данных в среду
СУБД

Правила ссылочной целостности
Правило целостности внешних ключей:
для каждого значения внешнего ключа должно существовать соответствующее значение первичного ключа в родительском отношении.
Ссылочная целостность может быть нарушена при выполнении операций:
1) обновление кортежа в родительском отношении;
2) удаление кортежа в родительском отношении;
3) вставка кортежа в дочернее отношение;
4) обновление кортежа в дочернем отношении.

Слайд 38

Особенности построения физической модели базы данных

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

Особенности построения физической модели базы данных Перенос логической схемы данных в среду
СУБД

Основные стратегии поддержания ссылочной целостности:
RESTRICT – не разрешать выполнение операции, приводящей к нарушению ссылочной целостности.
CASCADE – разрешить выполнение требуемой операции, но внести при этом необходимые поправки в других кортежах отношений так, чтобы не допустить нарушения ссылочной целостности и сохранить все имеющиеся связи.
Дополнительные стратегии поддержания ссылочной целостности:
NONE – никаких операций по поддержке ссылочной целостности не выполняется.
SET NULL – разрешить выполнение требуемой операции, но все возникающие некорректные значения внешних ключей заменять на неопределенные значения (null-значения).
SET DEFAULT – разрешить выполнение требуемой операции, но все возникающие некорректные значения внешних ключей изменять на некоторое значение, принятое по умолчанию.

Слайд 39

Особенности построения физической модели базы данных

Реализация бизнес-правил и анализ транзакций

После реализации бизнес-правил

Особенности построения физической модели базы данных Реализация бизнес-правил и анализ транзакций После
необходимо проверить выполнимость и эффективность всех транзакций.

Разработка механизмов защиты

Разработка пользовательских представлений
Представление в БД – динамический результат одной или более операций, выполненных над таблицами БД с целью получения новой сводной таблицы. Представление является виртуальной таблицей, которая реально в БД не существует, но создается по запросу (SELECT) определенного пользователя в результате выполнения этого запроса.
Определение прав доступа
Каждый пользователь обладает строго определенным набором прав (привилегий) в отношении конкретной таблицы или представления.

Слайд 40

Особенности построения физической модели базы данных

Организация мониторинга и настройка функционирования системы

Мониторинг необходим

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

Слайд 41

Особенности построения физической модели базы данных

Логическая модель данных системы
"Реализация средств вычислительной

Особенности построения физической модели базы данных Логическая модель данных системы "Реализация средств вычислительной техники"
техники"

Слайд 42

Особенности построения физической модели базы данных

Логическая модель данных системы

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

Слайд 43

Особенности построения физической модели базы данных

Выбор СУБД Target Database

Особенности построения физической модели базы данных Выбор СУБД Target Database

Слайд 44

Особенности построения физической модели базы данных

Физическая модель данных системы
"Реализация средств вычислительной

Особенности построения физической модели базы данных Физическая модель данных системы "Реализация средств вычислительной техники"
техники"

Слайд 45

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона"

Слайд 46

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Создадим новую сущность

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона" Создадим
«Клиент» со следующими атрибутами:
– Номер клиента (Primary Key, Number);
– Фамилия (String);
– Имя (String);
– Отчество (String);
– Телефон клиента (String).

Слайд 47

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона"

Слайд 48

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона"

Слайд 49

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Установим связи между

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона" Установим
сущностями:
– классификация → автомобиль (идентифицирующая связь);
– автомобиль → продажа (идентифицирующая связь);
– отдел → менеджер (неидентифицирующая связь);
– менеджер → продажа (идентифицирующая связь);
– клиент → продажа (идентифицирующая связь).

Слайд 50

Пример построения модели базы данных

Логическая модель данных системы
«Деятельность автосалона"

Пример построения модели базы данных Логическая модель данных системы «Деятельность автосалона"
Имя файла: Разработка-баз-данных.pptx
Количество просмотров: 44
Количество скачиваний: 0