Справочник по Windows Server 2003 (MCSE)

         

Создание базы данных

Создав одну таблицу (например, так, как вы это делали па занятии 2), вы уже получаете полноценную базу данных. Однако в реальной жизни структуры баз данных, а соответственно и способы их создания, намного сложнее. На этом занятии будут рассмотрены лишь некоторые из них.

 

Упражнение 1. Мастер таблиц

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

Например, чтобы создать таблицу данных, предназначенную для хранения списка людей, с которыми вы контактируете, выполните следующие действия.
     Запустите Microsoft Access, выполнив соответствующую команду меню Пуск > Программы (Start > Programs).  В появившемся в области задач приложения окне Создание файл? (New File) в разделе Создание (New) щелкните на пункте Новая база данных (Blank Access Database) (рис. 16.1).
Откроется окно диалога Файл новой базы данных (File New Database).

Рис. 16.1. Окно Microsoft Access

  1. Выберите для размещения новой базы данных папку Мои документы (My Documents). В поле Имя файла (File Name) введите имя Контакты. Затем щелкните па кнопке Создать (Create).
Примечание

После своего создания файл базы данных обновляется автоматически при закрытии и выполнении некоторых критических операций (например, изменении структуры таблицы). Нет необходимости вручную сохранять файл, хотя при долгой работе это следует делать во избежание потерь данных из-за сбоя компьютера.

Откроется окно базы данных, показанное на рис. 16.2. Оно является основным окном базы и позволяет открывать, добавлять и удалять любые объекты базы данных. В левой области окна находятся кнопки групп объектов. В его правой части расположен список объектов выбранного типа, имеющихся в текущей базе данных, а также значки команд, позволяющих создавать новые объекты данного типа. Пока что в этой базе данных нет ни одного объекта.
  1.  Щелкните на кнопке Таблицы (Tables).  Чтобы запустить мастер создания таблиц, дважды щелкните на значке Создание таблицы с помощью мастера (Create Table By Using Wizard).

Рис. 16.2. Окно базы данных В первом окне мастера, показанном на рис. 16.3, нужно указать подходящую структуру и выбрать в ней необходимый набор полей.

  1. Выберите положение переключателя Деловые (Business). В списке Образцы таблиц (Sample Tables) выберите пункт Контакты (Contacts). Щелкните на пункте Имя (FirstName) списка Образцы полей (Sample Fields).  Щелкните на кнопке со стрелкой вправо, чтобы добавить выбранное поле в структуру создаваемой таблицы.  Повторяя шаги 8 и 9, добавьте в список Поля новой таблицы (Fields In My New Table) поля Фамилия (LastName), Адрес (Address), НазваниеКомпании (Company Name) и РабочийТелефон (WorkPhone).  Щелкните на кнопке Далее (Next). В поле второго окна мастера введите слово Контакты, которое будет играть роль имени таблицы. Затем щелкните на кнопке Далее.

Рис. 16.3. Мастер создания таблиц

  1.  В третьем окне мастера щелкните на кнопке Готово (Finish). Мастер сгенерирует таблицу и откроет ее в режиме ввода данных.
Обратите внимание: поскольку во втором окне осталось выбранным положение переключателя Microsoft Access автоматически определяет ключ (Yes, Set A Primary Key For Me), Access добавляет в таблицу дополнительное ключевое поле Код_ Контакты (КонтактыЮ), которое играет роль уникального идентификатора записей.

 

Упражнение 2. Таблицы

Таблица данных похожа на лист электронной таблицы, но ее размеры ограничены. Число ее строк на единицу больше количества записей (последняя пустая строка предназначена для ввода новой записи), а число столбцов равно количеству полей в записи. Заголовки столбцов таблицы соответствуют именам полей, сформированных с помощью мастера создания таблиц.
     Щелкните на поле Имя и введите какое-нибудь имя. Access автоматически добавит в таблицу, созданную на предыдущем упражнении, первую запись, а строка новой записи сместится вниз. Введите фамилию в поле Фамилия.  Заполните все остальные поля первой записи.  Щелкните на поле Имя последней строки и введите имя еще одного человека, его фамилию, адрес, название компании и телефон. Добавьте подобным образом несколько записей, чтобы таблица стала такой, как показано на рис. 16.4. Если вы ошиблись при вводе, просто щелкните на ячейке с неверными данными и отредактируйте их. Стандартные заголовки столбцов часто оказываются неудобными, поэтому Access позволяет заменять их.

Рис. 16.4. Таблица данных

  1.  Щелкните на заголовке Фамилия правой кнопкой мыши и выберите команду Переименовать (Rename).  Введите слово Название, которое заменит подсвеченный заголовок Фамилия.  Повторив шаги 5 и 6, верните столбцу название Фамилия. Щелчком на кнопке Первая запись (First Record) переместите указатель теку щей записи в начало таблицы. Два раза щелкните на кнопке Следующая запись (Next Record), чтобы перейти к четвертой записи. Щелкните на кнопке Удалить запись (Delete Record) панели инструментов.  В появившемся окне запроса, информирующем о невозможности отмены операции удаления записи, щелчком на кнопке Да (Yes) подтвердите необходимость удаления. Обратите внимание, что ключевое поле Код_Контакты автоматически заполняется некоторыми числами. Эти числа не обязательно образуют непрерывную последовательность. Единственным условием является их уникальность. Содержимое ключевого поля различно для всех записей таблицы, что позволяет однозначно идентифицировать запись. Такие поля используются для формирования связей таблиц, о которых вы узнаете на этом занятии позже.

Конструктор таблиц

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

 

Упражнение 3. Структура таблицы

В упражнении 1 была создана таблица для хранения данных о людях, с которыми вы контактируете. Теперь давайте с помощью конструктора добавим в базу данных еще одну таблицу, предназначенную для записи всех случаев контакта с людьми из первой таблицы.
     Щелчком на кнопке Окно базы данных (Database Window) переключитесь на список таблиц базы данных. Дважды щелкните на значке Создание таблицы в режиме конструктора (Create Table In Design View). Окно конструктора, показанное на рис. 16.5, состоит из двух частей. В верхней отображается список полей таблицы, а в нижней — свойства выделенного поля.  Введите слово Дата, которое будет играть роль названия нового поля. Щелкните на ячейке Тип данных (Data Type) первой строки списка полей. Здесь необходимо выбрать тип поля, который определяет структуру и размер данных.

Рис. 16.5. Конструктор таблиц

  1. Щелкните на появившейся стрелке раскрывающегося списка ячейки Тип данных и выберите пункт Дата/время (Date/Time).  Нажмите клавишу Tab и введите расшифровку назначения поля: Дата контакта. Такие описания вводить не обязательно, но их наличие помогает разобраться в структуре таблицы.  Щелкните на второй ячейке столбца Имя поля (Field Name) и введите имя Описание. Задайте для второго поля тип Текстовый (Text). Укажите назначение поля в соответствии с рис. 16.5.
Кроме даты и описания контакта таблица данных должна содержать информацию о том, с кем вы контактировали. Но список людей хранится в таблице Контакты, поэтому в новой таблице не нужно заново вводить имя и фамилию. Достаточно лишь добавить ссылку на одну из записей таблицы Контакты. Эта ссылка будет иметь числовой тип и содержать число, равное значению поля Код_Контакты соответствующей записи таблицы Контакты.
  1.  Добавьте еще одно поле с именем Код_Контакты и типом Числовой (Number),
Теперь нужно добавить индексированное поле и назначить его ключом, однозначно' идентифицирующим записи таблицы. Индексированные поля, или индексы, отличаются от обычных тем, что для них Access создает специальные списки, позволяющие выполнять быструю сортировку и поиск по содержимому индексированного поля. Таблица может содержать несколько индексов. Ключ — это специальный индекс, идентифицирующий записи. Значения такого поля должны быть уникальными. Его наличие не обязательно, но оно так часто используется, что при отсутствии ключа Access напоминает об этом и предлагает автоматически добавить ключевое поле.
  1. Добавьте поле Ключ и назначьте ему тип Счетчик (AutoNumber). Такой тип данных избавляет пользователя от необходимости ввода значений ключевого поля и инициирует автоматическую генерацию уникальных значений.  Сохраняя активной строку Ключ, щелкните на кнопке Ключевое поле (Primary Key). На кнопке этой строки появится значок ключа, показывающий особый статус поля.  Щелкните на кнопке закрытия окна конструктора.  Access спросит о необходимости сохранения структуры таблицы. В ответ щелкните на кнопке Да.  В открывшемся окне диалога (рис. 16.6) введите имя Список.

Рис. 16.6. Ввод имени таблицы

  1.  Щелкните на кнопке ОК.

Упражнение 4. Список подстановки

Пришло время наполнить таблицу Список конкретной ин4юрмацией. Для этого выполните следующие шаги.
    В окне базы данных откройте список таблиц и дважды щелкните на значке Список. Выбранная таблица откроется в режиме просмотра данных.  Добавьте несколько записей в соответствии с рис. 16.7.

Рис. 16.7. Список состоявшихся контактов Примечание

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

Не забывайте, что числа в столбце Код_Контакты должны соответствовать номерам записей таблицы Контакты, описывающих людей, с которыми вы контактировали. Согласитесь, что искать соответствующие номера очень неудобно. Access позволяет автоматизировать эту операцию с помощью списка подстановки, который настраивается следующим образом.
  1.  Щелкните на кнопке Вид (View) панели инструментов. Откроется окно конструктора таблицы.  В списке типа данных для поля Код_Контакты выберите пункт Мастер подстановок (Lookup Wizard).  В первом окне мастера оставьте выбранным положение переключателя Объект «столбец подстановки» будет использовать значения из таблицы или запроса (I Want The Lookup Column To Look Up The Values In The Table Or Query) и щелкните на кнопке Далее. Три положения переключателя второго окна мастера выводят на экран список таблиц, запросов или объединяют эти два списка. Здесь нужно выбрать таблицу или запрос на роль источника подстановки. В нашем случае база данных кроме таблицы Список содержит только один объект — таблицу Контакты, которая и окажется выбранной в окне мастера.  Щелкните на кнопке Далее. Третье окно мастера, показанное на рис. 16.8, предлагает выбрать из таблицы Контакты поля, участвующие в подстановке. Этот список обязан содержать то поле, значения которого должны помещаться в поле Код_Контакты, то есть одноименное поле таблицы Контакты.  Щелкните на пункте Код_Контакты.

Рис. 16.8. Мастер подстановок

Рис. 16.9. Параметры подстановки

  1.  Щелкните на кнопке со стрелкой вправо. В список источника подстановки следует также добавить те поля, содержимое которых должно отображаться вместо численного значения, помещаемого из поля Код_Контакты таблицы Контакты в поле Код_Контакты таблицы Список. Я думаю, что будет удобно выбирать людей по их именам и фамилиям.  Добавьте в список Выбранные поля (Selected Fields) пункты Фамилия и Имя.  Затем щелкните на кнопке Далее.  В следующем окне мастер продемонстрирует два столбца таблицы-источника, скрыв столбец Код_Контакты, содержащий идентификатор записи. Щелкните на кнопке Далее.  В поле последнего столбца введите название Контакт, которое заменит имя столбца Код_Контакты, и щелкните на кнопке Готово.  В появившемся окне диалога щелчком на кнопке Да подтвердите необходимость сохранения построенной структуры.
Примечание

Параметры списка подстановки появятся на вкладке Подстановка (Lookup), показанной на рис. 16.9. Если вы знакомы с языком структурированных запросов SQL, то сможете разобраться в запросе Источник строк (Row Source), который формирует таблицу подстановки.

  1. Щелкните на кнопке Вид, чтобы снова переключиться в режим ввода данных.
Теперь в третьем столбце таблицы вместо чисел видны фамилии, соответствующие этим числам, хотя само значение поля Код_Контакты не изменилось. Access автоматически ищет соответствующую запись таблицы Контакты по числу, содержащемуся в поле Код_Контакты, и выводит в ячейку текст поля Фамилия — второго поля таблицы Контакты из выбранных в окне мастера подстановки. Давайте попробуем добавить в таблицу Список еще одну запись.

Рис. 16.10. Список подстановки

  1.  Щелкните на нижней ячейке столбца Дата и введите дату 10.10.97.  Нажмите клавишу Tab и напечатайте текст Письмо с предложениями о сотрудничестве.  Снова нажмите клавишу Tab и щелкните на появившейся кнопке раскрывающегося списка, как показано на рис. 16.10. Теперь вы можете выбирать людей из списка подстановки, сформированного на базе полей Фамилия и Имя таблицы Контакты.  Щелкните на втором пункте списка.
Access автоматически отыщет в таблице Контакты значение поля Код_Контакты для записи, содержащей информацию о Петре Петрове, и введет найденное число в поле Код_Контакты таблицы Список. Это значение останется скрытым. Вместо него в ячейке таблицы Список появится соответствующая фамилия, взятая из таблицы Контакты.

 

Упражнение 5. Связь таблиц

В предыдущем упражнении с помощью мастера подстановок была сформирована связь между двумя таблицами. Такая связь позволяет установить правила взаимодействия между таблицами. Список подстановок можно было организовать и без связи. Но представьте, что вы удалите из таблицы Контакты запись, на которую ссылаются некоторые записи таблицы Список. В такой ситуации останутся описания контактов, фамилии людей в которых потеряны. Наличие правильно организованной связи позволяет избежать подобных неприятностей. 
    Выберите команду Сервис > Схема данных (Tools > Relationships). Откроется окно, схематически изображающее связи базы данных. На рис. 16.11 видно, что линия связи соединяет поля Код_Контакты таблицы Контакты и Контакт таблицы Список.
Примечание

Данная связь соединяет ключевое и обычное поля. Это связь типа «один ко многим», когда одной записи таблицы Контакты может соответствовать несколько записей таблицы Список, но не наоборот.

Рис. 16.11. Схема данных Для тренировки давайте удалим связь, а затем создадим ее заново.

  1.  Щелчком выделите линию связи.  Нажмите клавишу Delete. В ответ на появившийся запрос щелкните на кнопке Да. Связь исчезнет.  Поместите указатель мыши на пункт Код_Контакты таблицы Контакты.  Нажмите кнопку мыши и перетащите указатель на поле Контакт таблицы Список.  В открывшемся окне диалога щелкните на кнопке Создать. Связь появится вновь.
Чтобы настроить параметры связи, выполните следующие шаги.
  1.  Дважды щелкните на линии связи. Откроется окно диалога, показанное на рис. 16.12.

Рис. 16.12. Параметры связи Примечание

Если таблицы, между которыми нужно организовать связь, отсутствуют, щелкните в окне Схема данных (Relationships) правой кнопкой мыши и выберите команду Добавить таблицу (Show Table). В открывшемся окне диалога выделяйте таблицы, которые нужно разместить в окне Схема данных и щелкайте на кнопке Добавить (Add). Получив все необходимые таблицы, закройте окно диалога кнопкой Закрыть (Close).

  1.  Установите флажок Обеспечение целостности данных (Enforce Referential Integrity). Этот режим не позволит Access оставлять в таблице Список записи, для которых нельзя подобрать запись таблицы Контакты с подходящим значением поля Код_Контакты.  Установите флажок Каскадное удаление связанных записей (Cascade Delete Related Records). Теперь при удалении записи таблицы Контакты (то есть удалении информации о конкретном человеке) будут удалены все соответствующие записи таблицы Список (то есть все описания контактов с этим человеком). Если указанный флажок сброшен, удаление тех записей таблицы Контакты, на которые ссылается хотя бы одна запись таблицы Список, запрещено.
Примечание

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

  1.  Щелкните на кнопке ОК.  Закройте окно Схема данных.  В окне базы данных дважды щелкните на значке таблицы Контакты. В открывшемся окне таблицы видны небольшие знаки «плюс», расположенные в левой части записей. Их присутствие говорит о наличии связи ключевого поля таблицы с другой таблицей. Щелкните на знаке «плюс» записи для Петра Петрова. Откроется вложенная таблица, содержащая те записи таблицы Список, значение поля Код_Кон-такты которых равно величине одноименного поля записи для Петра Петрова (рис. 16.13).

Рис. 16.13. Выборка данных из связанной таблицы Примечание

При раскрытии фрагмента связанной таблицы знак «плюс» превращается в знак «минус». Чтобы скрыть дополнительную таблицу, щелкните на нем еще раз.

  1.  Щелкните еще на каком-нибудь знаке «плюс», и вы увидите описание всех контактов с еще одним человеком. Таким образом, с помощью созданной связи вы можете быстро просматривать в окне таблицы Список описания всех контактов с определенным человеком или группой лиц.

Упражнение 6. Параметры поля

Для того, чтобы обеспечить возможность хранения в базе данных разнообразной информации, Access предлагает большой набор типов данных, перечисленных в табл. 16.1.

ТАБЛИЦА 16.1 . Типы данных

Название типа Назначение
Текстовый (Text) Текст длиной до 255 символов
Поле MEMO (Memo) Текст длиной до 65 000 символов
Числовой (Number) Числа различных форматов
Дата/время (Date/Time) Дата и/или время
Денежный (Currency) Денежные значения различных форматов
Счетчик (AutoNumber) Счетчик, который автоматически увеличивается на единицу с добавлением каждой новой записи
Логический (Yes/No) Величины, способные принимать только два значения: да/нет или 1/0
Поле объекта OLE (OLE Object) Поля, позволяющие вставлять рисунки, звуки и данные других типов
Гиперссылка (Hyperlink) Ссылки, дающие возможность открывать объект Access (таблицу, форму, запрос и т. п.), файл другого приложения или web-страницу

Чтобы сделать работу со списком контактов более продуктивной, следует изменить типы данных некоторых полей.
    В окне базы данных выделите таблицу Список и щелкните на кнопке Конструктор (Design), расположенной в верхней части окна. Выбранная таблица откроется в режиме конструктора.  Описание контакта может быть достаточно длинным, а максимальная длина текстовых полей ограничена 256 символами. Поэтому измените тип поля Описание на Поле MEMO.  Щелкните на поле Дата.

Рис. 16.14. Выбор формата

  1.  Для удобства прочтения даты контакта измените 4юрмат ее отображения, выбрав в раскрывающемся списке Формат поля (Format) пункт Длинный формат даты (Long Date), как показано на рис. 16.14.
Кроме типа данных и формата отображения вкладка Общие (General) окна конструктора позволяет настроить некоторые дополнительные параметры поля, влияющие на способ ввода данных. Параметр Значение по умолчанию (Default Value) задает содержимое поля, которое записывается в новую запись в том случае, если пользователь не ввел в это поле никаких данных. Если вы регулярно обновляете список контактов, то дата контакта чаще всего будет совпадать с текущей датой. Чтобы упростить ввод информации, можно задать текущую дату в качестве значения по умолчанию для поля Дата.
  1.  Введите в поле Значение по умолчанию (Default Value) функцию Date(), которая возвращает текущую дату. В некоторых случаях требуется не только задать тип данных поля, но и ограничить его возможные значения некоторым интервалом или более сложным правилом отбора. Такое правило вводится в поле Условие на значение (Validation Rule). Предположим, вы точно знаете, что все контакты, которые будут заноситься в список, состоятся после 1 января 1999 г. Чтобы избежать ошибок, можно заставить Access сообщать вам о вводе неверной даты. Для этого выполните следующие шаги. В поле Условие на значение щелкните на кнопке построителя выражений. Откроется окно диалога. Для задания условий или значений определенных параметров Access предлагает большой набор математических операций и функций. Построитель выражений помогает ориентироваться во всем многообразии функций Access. Верхнее прокручивающееся поле построителя содержит конструируемое выражение. Его можно изменять как путем непосредственного редактирования текста, так и с помощью других кнопок и списков построителя. Необходимо, чтобы дата записи была позднее, то есть больше, даты 1 января 1999 г. Поэтому щелкните на кнопке >, чтобы добавить нужное условие.
Теперь нужно указать дату, с которой выполняется сравнение. Дяя этого следует воспользоваться специальной функцией, преобразующей строковую константу в дату в формате Access.
  1.  Дважды щелкните на папке Функции (Functions) в левом списке построителя выражений.  Щелкните на папке Встроенные функции (Built-in Function), чтобы вывести список стандартных функций Access.  В среднем списке выберите категорию Дата/время.  Двойным щелчком на имени функции DateValue добавьте ее в поле выражения. Вместо местозаполнителя аргумента «stringexpr» нужно ввести конкретную дату в строковом формате.  В поле выражения щелчком выделите текст «stringexpr», а затем напечатайте "1.1.99".  Щелкните на кнопке ОК.

Рис. 16.15. Параметры поля Дата

  1. В поле Сообщение об ошибке (Validation Text) введите текст Неверная дата, который будет появляться при вводе даты, более ранней, чем 1 января 1999 г. Окончательный набор параметров поля Дата показан на рис. 16.15.  Щелкните на кнопке закрытия окна конструктора. В окне запроса на обновление структуры таблицы щелкните на кнопке Да. По причине добавления условий на значения поля Дата Access запросит о необходимости проверки содержимого этого поля в уже имеющихся записях таблицы. Щелкните на кнопке Нет (No), чтобы не выполнять проверку.
Давайте изучим влияние настроенных параметров на поведение базы данных.
  1.  Выделите таблицу Список в окне базы данных и щелкните на кнопке Открыть (Open). Теперь все даты отображаются в длинном формате, а в ячейке Дата в строке новой записи автоматически появляется текущая дата.  Щелкните в ячейке Дата второй строки, измените ее содержимое на 19.11.95 и нажмите клавишу Tab, чтобы перейти к следующему полю. Так как модифицированная дата предшествует 1 января 1999 г., что противоречит настроенному условию, Access не позволит убрать курсор из текущей ячейки и откроет окно сообщения  с текстом, введенным вами в поле Сообщение об ошибке конструктора таблицы на шаге 14. Такое сообщение будет появляться до тех пор, пока вы не скорректируете дату.
  1.  Щелкните на кнопке ОК.  Исправьте дату на 19.11.00.  Закройте таблицу Список.

Упражнение 7. Индекс

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

Рис. 16.16. Сортировка фамилий по алфавиту

  1.  Щелчком на кнопке Сортировка по возрастанию (Sort Ascending) упорядочите записи столбца фамилии таблицы по алфавиту (рис. 16.16).  Вставьте в таблицу еще несколько человек с фамилией Петров. Например, Василий Петров, Николай Петров и Игорь Петров. Добавляйте записи в указанном порядке.  Чтобы обновить сортировку, закройте окно таблицы Контакты и вновь откройте таблицу. Записи окажутся расположенными так, как показано на рис. 16.17.

Рис. 16.17. Несколько человек с одинаковыми фамилиями Фамилии упорядочены по алфавиту, но имена людей расставлены в беспорядке. Если бы в таблице было несколько сотен людей с фамилией Петров, то поиск нужного человека существенно бы осложнился. Чтобы выполнить сортировку сразу по нескольким полям, следует воспользоваться сложным индексом. Его настройка выполняется посредством следующих действий.

  1.  Щелчком на кнопке Вид переключитесь в режим конструктора.  Чтобы открыть окно индексов таблицы Контакты, показанное на рис. 16.18, щелкните на кнопке Индексы (Indexes) панели инструментов. В окне индексов есть список со столбцами названия индекса, имени поля, по которому выполняется индексация, и режима сортировки (по возрастанию или по убыванию). Мастер таблиц при создании таблицы Контакты индексировал ее потрем полям: Название Компании, Фамилия, Код_Контакты, добавив индексы с именами соответственно: Название Компании, Фамилия и PrimaryKey. Последний из трех индексов является ключом таблицы, однозначно идентифицирующим ее записи. Все имеющиеся индексы простые, то есть назначают сортировку только по одному полю. Чтобы записи с одинаковыми фамилиями располагались по алфавиту имен, следует модифицировать индекс Фамилия, добавив в него условие сортировки по полю Имя. Для этого выполните следующие шаги.

Рис. 16.18. Индексы

  1.  Щелкните правой кнопкой мыши на той строке, которая расположена ниже строки индекса Фамилия.  Выберите в контекстном меню команду Добавить строки (Insert Rows), чтобы вставить одну пустую строку.  В новой строке щелкните на кнопке раскрывающегося списка ячейки Имя поля.  Выберите пункт Имя. В столбце Порядок сортировки (Sort Order) автоматически появится вариант По возрастанию (Ascending).

Рис. 16.19. Сортировка по двум полям В окне настройки индексов имена полей, по которым происходит упорядочивание в данном индексе, располагаются в строке с именем индекса и ниже ее в строках с пустой ячейкой Индекс (Index Name) в порядке убывания влияния поля. То есть первой выполняется сортировка по тому полю, которое в данном индексе расположено выше. В одном индексе можно использовать до 10 полей. Таким образом, теперь индекс Фамилия упорядочивает записи по алфавиту сначала по фамилиям, а потом по именам.

  1.  Закройте окно индексов.  Щелкните на кнопке Вид, чтобы переключиться в режим редактирования таблицы.  Ответьте Да на запрос о необходимости сохранения таблицы. Теперь имена оказались выстроенными по алфавиту, как показано на рис. 16.19. Поскольку перед этим уже была настроена сортировка по полю Фамилия (то есть по индексу Фамилия, главным полем которого является Фамилия), вам даже не пришлось перенастраивать сортировку. Модификация индекса автоматически привела к упорядочению имен.

Контрольное упражнение

Пришло время самостоятельно попрактиковаться в работе с конструктором таблиц. Access автоматически обновляет файл базы данных. Чтобы сохранить его исходный вариант, в Проводнике создайте копии файлов Контакты.mdb и Список.mdb — соответственно файлы Контакты_копия.mbd и Список_копия.таЬ. Закончив контрольное упражнение, переименуйте файлы Контакты_копия.mbd и Список_копия.mbd обратно в Контакты.mdb и Список.mdb.
     Откройте таблицу Контакты в режиме конструктора.  Измените тип данных поля Адрес на Поле MEMO.  Ограничьте длину текстового поля Имя величиной 30 символов. Какой параметр определяет длину поля?  Поле Фамилия является ключевым. Запретите Access добавлять в таблицу Контакты записи с пустым полем Фамилия.  Как запретить добавление пустого поля?
  1.  Закройте конструктор и сохраните структуру таблицы. Создайте новую таблицу с именем Метод.  В конструкторе добавьте в нее поле Метод ID с типом данных Счетчик и поле Вариант с типом Текстовый. Первое из них сделайте ключом таблицы.  Переключитесь в режим редактирования и введите в таблицу три записи, в поле Метод которых введите слова Телефон, Письмо, Факс. Эта таблица будет хранить возможные способы контакта.  С помощью конструктора добавьте в таблицу Список поле Метод ID с числовым типом.  С помощью мастера подстановки назначьте этому полю подстановку, состоящую из полей МетодЮ и Вариант таблицы Метод. Как сделать, чтобы в список подстановки кроме названия метода выводился его кодовый номер?
  2.  В имеющихся записях таблицы Список введите значение в новое поле, выбрав его в списке подстановки. Закройте базу данных. Какие операции закрывают базу данных?

Подведение итогов

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