
- •Базы данных Лабораторный практикум
- •Общая постановка задачи на практические занятия и требования к программной реализации
- •Практическое занятие 1 Проектирование базы данных
- •1.1. Концептуальное проектирование базы данных
- •1.1.1. Определение типов сущностей
- •1.1.2. Определение типов связей
- •1.1.3. Определение атрибутов и связывание их с типами сущностей и связей
- •1.1.4. Определение доменов атрибутов
- •1.1.5. Определение атрибутов, являющихся потенциальными и первичными ключами
- •1.2. Логическое проектирование базы данных (для реляционной модели)
- •1.2.1. Преобразование локальной концептуальной модели данных в локальную логическую модель
- •1.2.2. Определение набора отношений, исходя из структуры локальной логической модели данных
- •1.2.3. Проверка модели с помощью правил нормализации
- •1.2.4. Создание диаграмм «сущность-связь» логической модели
- •1.3. Физическое проектирование базы данных (с использованием реляционной субд)
- •1.3.1. Имена полей таблицы
- •1.3.2. Типы данных
- •2.1. Работа с таблицами
- •2.1.1. Создание таблиц
- •2.1.1.1. Создание таблиц через меню
- •2.1.2. Изменение структуры таблиц
- •2.1.3. Копирование таблиц
- •2.1.4. Удаление таблиц
- •2.1.5. Использование рабочих областей
- •2.2. Манипулирование данными в таблице
- •2.2.1. Ввод данных
- •2.2.2. Удаление записей
- •2.2.3. Редактирование данных
- •2.2.4. Фильтрация данных
- •2.3. Работа с индексами
- •2.3.1. Создание индексов
- •Index on good_name to ind_non_uniq будет создан индекс по всем значениям поля good_name (рис. 2.15).
- •2.3.2. Удаление индексов
- •2.4. Реструктуризация базы данных
- •2.4.1. Создание базы данных
- •2.4.2. Работа с таблицами в базе данных
- •2.4.2.2. Редактирование таблиц в базе данных
- •2.4.3. Связи в базе данных
- •2.4.4. Удаление базы данных
- •Практическое занятие 3 Программирование на языке FoxPro
- •3.1. Создание программ
- •4.1. Работа с формами
- •4.1.1. Создание формы
- •4.1.1.2. Создание форм по нескольким таблицам с помощью мастера
- •4.1.4. Удаление формы
1.2.3. Проверка модели с помощью правил нормализации
Нормализация используется для улучшения модели данных для того, чтобы модель удовлетворяла различным ограничениям, позволяющим исключить нежелательное дублирование данных. Нормализация гарантирует, что полученная в результате ее применения модель данных будет наилучшим образом отображать особенности использования информации на предприятии, не содержать противоречий, иметь минимальную избыточность и максимальную устойчивость.
В теории реляционных баз данных обычно выделяется следующая последовательность нормальных форм:
первая нормальная форма (1NF);
вторая нормальная форма (2NF);
третья нормальная форма (3NF);
нормальная форма Бойса-Кодда (BCNF);
четвертая нормальная форма (4NF);
пятая нормальная форма, или нормальная форма проекции-соединения (5NF или PJ/NF).
Основные свойства нормальных форм:
каждая следующая нормальная форма в некотором смысле лучше предыдущей;
при переходе к следующей нормальной форме свойства предыдущих нормальных свойств сохраняются.
Таким образом, каждая нормальная форма является в некотором смысле более ограниченной, но и более желательной, чем предшествующая. Это связано с тем, что (N+1)-a нормальная форма не обладает некоторыми непривлекательными особенностями, свойственным N-й нормальной форме. Общий смысл дополнительного условия, налагаемого на (N+^-ю нормальную форму по отношению к N-й нормальной форме, состоит в исключении этих непривлекательных особенностей. Определения нормальных форм приведены в приложении 1.
В нашем примере база данных приведена к первой нормальной форме (так как ни одна из строк таблиц не содержит в любом своем поле более одного значения, т.е. все значения атрибутов атомарны), ко второй нормальной форме (так как нет атрибутов, частично зависящих от ключевого поля) и к третьей нормальной форме (так как нет транзитивных зависимостей).
1.2.4. Создание диаграмм «сущность-связь» логической модели
данных
После всех преобразований итоговая логическая модель базы данных представлена на рис. 1.3.
Товар (Good)
Наименование товара
Фирма-производитель
Уникальный индекс
Цена
Цвет
>
(Firm)
Название фирмы
Адрес
Телефон
производится
I Производитель
Рис. 1.3. Итоговая логическая модель базы данных учета товара в обувном магазине
1.3. Физическое проектирование базы данных (с использованием реляционной субд)
Физическое проектирование заключается в переносе логической модели данных в выбранную СУБД (в нашем случае в СУБД Visual FoxPro).
1.3.1. Имена полей таблицы
Имя поля таблицы в СУБД Visual FoxPro может состоять из 254 символов для таблиц, включенных в базу данных, и 10 символов для свободных таблиц (не включенных в базу данных). В имени поля можно применять буквы, цифры и знак подчеркивания. Использование знаков препинания, специальных символов и пробелов в имени поля не рекомендуется. Также имя поля не должно начинаться с цифры или знака подчеркивания [2]. Выберем имена для сущностей и атрибутов логической модели данных (табл. 1.2 и табл. 1.3).
Таблица 1.2. Таблица Goods
Наименование поля |
Комментарии |
Good_name |
Наименование товара |
Firm |
Фирма-производитель |
Index |
Уникальный индекс на складе |
Price |
Цена |
Colour |
Цвет |
Amount |
Количество |
Таблица 1.3. Таблица Firms
Наименование поля |
Комментарии |
Firm_name |
Название фирмы |
Address |
Адрес |
Telephone |
Телефон |
Director f |
ФИО директора |
Director n |
|
Director o |
|
Account |
№ банковского счета |