Добавлен: 15.11.2018
Просмотров: 6691
Скачиваний: 11
71
которой невозможно существование записи в подчиненной таблице без
соответствующей записи в главной таблице.
Размещение сведений о каждой сущности в отдельной таблице и связывание
таблиц позволяет избежать повторения данных, противоречивости, упрощает
обновление информации и поиск в БД.
Каждое поле в таблице имеет определенный формат и заданный по
умолчанию тип. Access поддерживает все необходимые типы полей: Текстовый —
для хранения одной строки текста, Числовой — для чисел. Денежный — для
представления денежных величин. Дата/время — для времени, MEMO — для
хранения произвольной информации. Логический — для логических значений, Поле
объекта OLE — для хранения объектов из других приложений, поддерживающих
технологию OLE, Гиперссылка – для перехода к объектам той же самой или другой
базы данных, к документам, созданным в MS Word, MS Excel и MS PowerPoint, а
также к документам, расположенным в глобальной сети Интернет, Мастер
подстановок – для создания списка значений из ссылочной таблицы.
Важной характеристикой СУБД является поддержка целостности (корректности
информации) БД. Поддержка целостности может реализовываться в СУБД
различными способами, что позволяет выделить несколько её видов:
после определения типа поля БД СУБД контролирует вводимые в них
значения;
свойство поля – размер является дополнением к ограничению по типу;
условие на вводимые значение;
маска;
индексирование поле служит для контроля уникальности;
Ссылочная целостность данных означает систему правил, используемых в
Access для поддержания связей между записями в связанных таблицах, а также
обеспечивает защиту от случайного удаления или изменения связанных данных.
Установить ссылочную целостность данных можно, если выполнены следующие
условия:
связанное поле главной таблицы является ключевым полем или имеет
уникальный индекс;
связанные поля имеют один тип данных. Здесь существует
исключение. Поле счетчика может быть связано с числовым полем,
если в последнем в свойстве Размер поля указано значение «Длинное
целое»;
В СУБД Access процесс создания реляционной БД включает создание схемы
данных. Схема данных наглядно отображает таблицы и связи между ними.
Базой данных в СУБД Access является совокупность таблиц, форм, отчетов,
запросов, макросов, хранящихся в одном файле типа .mdb.
2. Порядок выполнения работы
1.
Создайте базу данных ДЕКАНАТ, выполнив следующие действия:
загрузите Access, в появившемся окне в меню Файл / Создание / Пустая
база данных рабочего стола;
72
в окне Файл новой базы данных укажите вашу папку для размещения
базы данных и укажите имя БД -- Деканат- «Ваша фамилия» -. По
умолчанию Access предлагает вам имя базы db1., а тип файла – mdb.
(Выбор диска для хранения БД, уточняется у преподавателя)
нажмите кнопку Создать.
2.
Создайте структуру таблицы ПРЕПОДАВАТЕЛИ. Для этого:
в окне базы данных выберите вкладку Создать, далее пункт
Конструктор таблиц. В результате проделанных операций открывается
окно таблицы в режиме конструктора, в котором следует определить
поля таблицы.
Определите поля таблицы в соответствии с табл. 9.
Таблица 9 Структура таблицы Преподаватели
Имя поля
Тип данных
Размер поля
Код преподавателя
Числовой
Целое
Фамилия
Текстовый
15
Имя
Текстовый
13
Отчество
Текстовый
15
Дата рождения
Дата/время
(маска)
Должность
Мастер подстановок
25
поле
со
списком
Стаж
Числовой
Целое (условие на
значение
>0,
вывод
соответствующего
сообщения об ошибке)
Кафедра
Текстовый
11
Телефон
Текстовый
9 (маска)
Зарплата
Денежный
При определении поля ДАТА РОЖДЕНИЯ используем маску для удобного
ввода даты (т.е. в датах точки будут вводится автоматически). Для этого в
Свойства полей на вкладке Общие установите курсор на поле маска, справа
появится кнопка с тремя точками – нажмите на неё. В появившемся окне
создания масок выбирайте КРАТКИЙ ФОРМАТ ДАТЫ.
В поле ДОЛЖНОСТЬ используем мастер подстановок для того, чтобы не
вводить, а выбирать из списка нужную должность, с возможностью ввода
должности, которой нет в списке. В режиме СОЗДАНИЯ ПОДСТАНОВОК
выбираем ФИКСИРОВАННЫЙ НАБОР ЗНАЧЕНИЙ, далее создаем 1 столбец
с должностями: профессор, доцент, старший преподаватель, ассистент.
73
Закончив создание списка в режиме конструктора на вкладке Подстановка
(свойства поля) посмотрите появившиеся изменения после работы мастера.
Проверьте строку Ограничиться списком, в котором должно стоять слово Нет.
В поле СТАЖ в общих свойствах поля установите Правило проверки >0,
Сообщение об ошибке введите - стаж должен быть больше 0.
В поле ТЕЛЕФОН наберите маску для ввода 999-99-99, которая позволит не
набирать тире в номере телефона при вводе в поле. (подробнее о маске см.
help)
В качестве ключевого задайте поле КОД ПРЕПОДАВАТЕЛЯ (нажатием
правой кнопки мыши на поле).
3.
Таблица СТУДЕНТ будет импортирована из таблицы Excel (файл
студент.xls местонахождение таблицы узнать у преподавателя)
Вкладка в меню Внешние данные \ Excel
Отредактируйте структуру созданной таблицы в режиме конструктора
Таблица 10 Структура таблицы Студент
Имя поля
Тип данных
Размер поля
Код студента
Числовой
Целое
Фамилия
Текстовый
15
Имя
Текстовый
12
Отчество
Текстовый
15
Номер группы
Числовой
Целое
Адрес
Текстовый
30
Телефон
Текстовый
9 (маска)
Медалист
Текстовый
4
Поле
со
списком(Да/Нет)
по умолчанию
нет
В качестве ключевого задайте поле КОД СТУДЕНТА. Для этого щелкните по
полю КОД СТУДЕНТА и выполните команду Правка
Ключевое поле;
Для удобства ввода телефона задайте маску 999-99-99
В поле МЕДАЛИСТ создайте Поле со списком (Свойства поля \ Подстановка \
Тип элемента управления) без ввода новых значений, в Тип источника строк
выберите СПИСОК ЗНАЧЕНИЙ, Источник строк задайте "ДА" и "НЕТ", а также
задайте Значение по умолчанию “НЕТ” (кавычки обязательны).
74
4.
Создайте структуру таблицы ДИСЦИПЛИНЫ в соответствии с табл.11.
Таблица 11 Структура таблицы Дисциплины
Имя поля
Тип данных
Размер поля
Код дисциплины
Числовой
Целое
Название
дисциплины
Текстовый
30
Номер семестра
Числовой
Целое
Код преподавателя
Числовой
Целое
(мастер
подстановок)
Экзамен
Текстовый
4 (поле со списком
экз/зач)
В качестве ключевого задайте поле КОД ДИСЦИПЛИНЫ.
Поле КОД ПРЕПОДАВАТЕЛЯ будет заполняться при помощи мастера
подстановок из таблицы ПРЕПОДАВАТЕЛИ. Из доступных полей таблицы
ПРЕПОДАВАТЕЛИ выберите, КОД ПРЕПОДАВАТЕЛЯ ФАМИЛИЯ, ИМЯ,
ОТЧЕСТВО, скройте ключевое поле. После работы мастера при заполнении
поля КОД ПРЕПОДАВАТЕЛЯ таблицы будут отображатся ФИО преподавателя
для выбора, но в таблице ДИСЦИПЛИНЫ поле КОД ПРЕПОДАВАТЕЛЯ будет
оставаться числовым целым
Поле ЭКЗАМЕН заполняйте при помощи поля со списком двух значений Экз или
Зач
5.
Таблица ОЦЕНКИ будет импортирована из базы данных ОЦЕНКИ (файл
оценки.mdb) Местонахождение файла узнать у преподавателя)
Меню Внешние данные / Access
6.
Отредактируйте структуру таблицы ОЦЕНКИ в соответствии с табл. 12.
Таблица 12Структура таблицы Оценки
Имя поля
Тип данных
Размер поля
Код студента
Числовой
Целое
(мастер
подстановок
Код дисциплины
Числовой
Целое
(мастер
подстановок Целое
Номер семестра
Числовой
Целое
Оценки
Числовой
Байт
75
ключ будет составной: код студента (подстановка ФИО СТУДЕНТА), код
дисциплины (подстановка название дисциплины), номер семестра. (в режиме
конструктора выделите три поля и задайте ключ)
Эта таблица уже заполнена.
7.
Разработайте схему данных, т.е. создайте связи между таблицами. Для
этого:
Выполните команду Работа с базами данных
Схема данных. На экране
появится окно "Схема данных" и сама схема данных с установленными
связями между таблицами;
Если же схема данных автоматически не появилась, то выполните команду
Отобразить таблицу;
В появившемся окне будет выделено название одной таблицы. Нажмите
кнопку Добавить;
Переведите выделение на имя следующей таблицы и нажмите кнопку
Добавить. Аналогично добавьте оставшиеся две таблицы;
Закройте окно нажав кнопку Закрыть;
Создайте связь между таблицами ДИСЦИПЛИНЫ и ОЦЕНКИ. Для этого
подведите курсор мыши к полю КОД ДИСЦИПЛИНЫ в таблице
ДИСЦИПЛИНЫ, нажмите левую клавишу мыши и, не отпуская ее,
перетащите курсор на поле КОД ДИСЦИПЛИНЫ в таблице ОЦЕНКИ, а затем
отпустите левую клавишу мыши. На экране откроется окно "Связи";
Щелкните по ячейке Обеспечение целостности данных – в ней должна
появиться галочка;
Щелкните по ячейкам Каскадное обновление связанных полей и Каскадное
удаление связанных записей.
Информация.
Задание каскадного обновления связанных полей и каскадного
удаление связанных записей позволит вам редактировать записи только в таблице
ДИСЦИПЛИНЫ, а в таблице ОЦЕНКИ эти действия будут со связанными записями
выполняться автоматически. Например, если вы удалите из таблицы ДИСЦИПЛИНЫ один
предмет, то в таблице ОЦЕНКИ удалятся все строки, связанные с этим предметом.
Нажмите кнопку ОК. Связь будет создана;
Аналогично создайте связи между полем КОД ПРЕПОДАВАТЕЛЯ в таблице
ПРЕПОДАВАТЕЛИ
и
полем
КОД
ПРЕПОДАВАТЕЛЯ
в
таблице
ДИСЦИПЛИНЫ, а также между полем КОД СТУДЕНТА в таблице СТУДЕНТЫ
и полем КОД СТУДЕНТА в таблице ОЦЕНКИ;