Файл: В.В. Крюкова Проектирование, создание и использование баз данных MS ACCESS Часть 2. Физическое проектирование базы данных.pdf

ВУЗ: Не указан

Категория: Не указан

Дисциплина: Не указана

Добавлен: 31.05.2024

Просмотров: 50

Скачиваний: 0

ВНИМАНИЕ! Если данный файл нарушает Ваши авторские права, то обязательно сообщите нам.

16

УСТАНОВКА СВЯЗЕЙ МЕЖДУ ТАБЛИЦАМИ

Создание связей между таблицами – последний этап физического проектирования БД. Связь между таблицами устанавливает отношение между совпадающими значениями в ключевых полях. В большинстве случаев связывают первичный ключ главной таблицы с внешним ключом подчинённой таблицы (часто имеющим то же имя), например, первый ключ Код контрагента таблицы Контрагенты и внешний ключ Код контрагента таблицы ЖХО. Существуют четыре типа отношений:

1.Один – к одному 1 1. Запись таблицы А может иметь не более одной связанной записи в таблице В и наоборот. Ключевое поле в таких таблицах должно быть уникальным.

2.Многие – к одному ∞ ↔ 1. Одной записи в таблице А может соответствовать одна запись в таблице В, а одной записи в таблице В – несколько записей в таблице А. В таблице В ключевое поле должно быть уникальным.

3.Один – ко многим 1 ↔ ∞. Каждой записи в таблице А могут соответствовать несколько записей в таблице В, а запись в таблице В не может иметь более одной соответствующей записи в таблице А. В таблице А ключевое поле должно быть уникальным. Отношения

вида 1 ↔ ∞ и ∞ ↔ 1 отличаются тем, какая таблица является главной.

4.Многие – ко многим ∞ ↔ ∞. Такая таблица не нормализована. Одной записи таблицы А может соответствовать несколько записей таблицы В и наоборот. Уникальных ключей нет. Все ключи внешние. В этом случае таблицу надо нормализовать, используя инст-

румент Анализатор таблиц (меню Сервис, Анализ, Таблица, запус-

кается мастер).

Связанные поля не обязательно должны иметь одинаковые имена

(поле Номер счёта таблицы План счетов и поле Дебет таблицы ЖХО),

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


17

 

 

 

 

 

 

 

Находясь в окне

 

БД,

нажать кнопку

 

Схема данных,

затем

 

Добавить

таблицу

 

(или

команда

меню

 

Связи,

Добавить

 

таблицу),

появится

 

окно

 

Добавление

 

таблицы

(рис. 14).

 

Выбрать

таблицу

из

 

списка

(один

 

раз

Рис. 14. ДО Добавление таблицы

щёлкнуть

 

левой

кнопкой

мыши)

и

 

нажать кнопку Доба-

вить, выбрать следующую таблицу, нажать кнопку Добавить и т.д. Выбрать все таблицы, затем нажать кнопку Закрыть. Затем уцепить левой кнопкой мыши поле первой таблицы со стороны связи 1 и тащить, опустить на то же поле другой таблицы, появится ДО Изменение связей (рис. 15), внизу указан тип отношения один – ко многим, нажать кнопку Создать. Для удаления связи – щёлкнуть правой кнопкой мыши нужную связь и выбрать команду Удалить, для изменения – два раза щёлкнуть линию связи, появится ДО Изменение связей, которое имеет три флажка: Обеспечение целостности данных означает выполнение ус-

ловий корректного внесения записей, Каскадное обновление связан-

ных полей, Каскадное удаление связанных полей означают, что при изменении (или удалении) значений первичного ключа главной табли-

 

цы автоматически

меня-

 

ются (или удаляются) со-

 

ответствующие значения

 

внешнего

ключа подчи-

 

ненной

таблицы.

Связи

 

следует

 

создавать

при

 

пустых

таблицах,

иначе

 

нельзя

будет установить

 

эти параметры целостно-

 

сти БД (или какой-либо

 

из них).

 

составном

Рис. 15. ДО Изменение связей

При

ключе в окне Изменение


Рис. 16. Параметры объединения

18

связей необходимо для каждого ключа главной таблицы (Таблица) выбрать соответствующее поле подчинённой таблицы (Связанная таблица). При установлении связи по составному ключу необходимо выделить все поля, входящие в ключ главной таблицы, и перетащить их на одно из полей связи в подчинённой таблице. При выделении полей удерживать клавишу <Ctrl>.

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

Если в ДО Изменение связей нажать кнопку Объединение, откро-

ется ДО Параметры объединения – критерии для отбора записей (рис. 16). Например, для любого типа связи можно выбрать:

1. Объединение только тех записей, в которых связанные поля обеих таблиц совпа-

дают (внутреннее объединение).

2. Объединение всех записей из таблицы А и только тех из таблицы В, в которых связанные поля совпадают (левое внешнее объединение).

3. Объединение всех записей из таблицы В и только тех из таблицы А, в которых связан-

ные поля совпадают (правое внешнее объединение).

Для связей между таблицами на уровне БД лучше использовать только внутреннее объединение, а оба внешние объединения – при создании запросов.

В MS Access 2000 существуют два способа организации связи: создание непосредственных связей (вручную) с помощью инструмента Схема данных и создание вложенных таблиц. Чтобы создать вложенную таблицу, надо открыть главную таблицу в режиме просмотра, активизировать поле первичного ключа (необязательно) и выполнить команду меню Вставка, Подтаблица, появится ДО, в котором выбрать подчинённую таблицу и указать: в списке Подчинённые поля – внешний ключ (первичный ключ подчинённой таблицы) и в списке Основные поля – первичный ключ главной таблицы, ОК. Рядом с именем поля пер-

19

вичного ключа главной таблицы появится знак . При щелчке мыши по нему открывается подчинённая (связанная) таблица.

Установим связи между таблицами БД “Бухгалтерский учёт на предприятии” (рис. 17). Если в ДО

Изменение связей вид связи определяется неправильно или вообще не определён, следует вернуться к этапу конструирования таблиц, проверить свойства первичных и внешних ключей, изменить

Рис. 17. Схема данных при необходимости.

Схема данных

графическое представление физической модели БД, полностью соответствует логической МД (рис. 1).

МАКЕТ ТАБЛИЦЫ

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

Настройка макета выполняется в режиме таблицы, используется:

команда меню Формат и ПИ Формат (режим таблицы). Многие опе-

рации можно выполнять мышью: изменить ширину, высоту, скрыть столбцы (перетащив правую границу влево до исчезновения столбца), изменить порядок следования – выделить столбец (мышью щелкнуть по заголовку) и перетащить в нужное место, удалить столбцы, закрепить столбцы (команда меню Формат). Сохранить изменения: ответить Да на вопрос “Сохранить макет таблицы?”



20

ИМПОРТ И ПРИСОЕДИНЕНИЕ ВНЕШНИХ ТАБЛИЦ

Импорт и присоединение таблиц – ещё один способ создания таблиц в активной (открытой) БД. Можно импортировать или присоединить таблицу из другого файла БД MS Access, рабочий лист (список) MS Excel, таблицу из файла БД в других форматах (например, .dbf и др.). Разница между импортом и присоединением внешней таблицы заключается в том, что при импорте таблица физически помещается в активную БД и последующие изменения в ней не отражаются на источнике, а в результате присоединения в активную БД помещается только ссылка на внешнюю таблицу. Присоединённая таблица сохраняет связь с источником, и любое изменение данных в ней автоматически сохраняется во внешней БД-источнике. Импорт и присоединение таблиц осуществляется из меню Файл, Внешние данные командами Импорт и Связь с таблицами соответственно.

ЛАБОРАТОРНАЯ РАБОТА № 2

Создание таблиц БД в MS Access

Задание:

1.Используя Режим конструктора, Режим таблицы и Мастер таблиц, создать таблицы БД своей предметной области разными способами в соответствии с логической МД.

2.Определить типы данных полей, включая MEMO, объект OLE и

выбор из списка (Мастер подстановок).

3.Для некоторых полей задать свойства Маска ввода.

4.Для каждой таблицы определить первичные и внешние ключи.

5.Для внешнего ключа подчинённой таблицы определить поле подстановки, указав в качестве столбца данных поле первичного ключа главной таблицы.

6.Создать схему данных. В диалоговом окне Изменение связей

включить флажки: Обеспечение целостности данных, Каскадное обновление и удаление связанных полей.

21

СПИСОК РЕКОМЕНДУЕМОЙ ЛИТЕРАТУРЫ

1.Новиков Ф.А. Microsoft Office 2000 в целом / Ф.А. Новиков,

А.Д. Яценко. – СПб.: БХВ – Петербург, 2001. – 728 с.

2.Программирование в среде Access 2000: Энциклопедия пользователя; Пер. с англ. / Стивен Форт, Том Хоун, Джеймс Релстон. – Киев: ДиаСофт, 2000. – 544 с.

3.Дубнов П.Ю. Access 2000. Проектирование баз данных. – М.:

ДМК, 2000. – 272 с.

4.Послед Б.С. Access 2000. Базы данных и приложения. – Киев:

ДиаСофт, 2000. – 512 с.

5. Бекаревич Ю.Б. Самоучитель Microsoft Access 2000 /

Ю.Б. Бекаревич, Н.В. Пушкина. – СПб.: БХВ-Санкт-Петербург, 1999. – 480 с.