Работа в Microsoft Access XP

         

Просмотр базы данных, созданной мастером


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

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

Contacts

В этом упражнении вы воспользуетесь кнопочной формой, чтобы оценить результаты работы мастера по созданию базы данных Контакты. Поскольку для этого требуется, чтобы база содержала информацию, параллельно с просмотром объектов вы введете данные в некоторые таблицы. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap10\CreatingDb. Выполните следующие шаги.

Откройте базу данных Контакты, расположенную в рабочей папке. На главной кнопочной форме щелкните на кнопке Ввод/просмотр других сведений, чтобы отобразить кнопочную форму, которая содержит две кнопки. Первая кнопка открывает форму для ввода и просмотра типов контактов, а вторая возвращает в главную кнопочную форму. Щелкните на кнопке Ввод/просмотр формы "Типы контактов", чтобы отобразить форму Типы контактов.


Если бы таблица Типы контактов содержала данные, можно было бы воспользоваться формой для их просмотра. Единственное, что можно сделать сейчас, - это ввести новую запись.В поле Тип контакта введите Поставщик и нажмите на клавишу (Enter). При добавлении новой записи поле Код типа контакта заполняется автоматически следующим доступным значением кода. Повторите предыдущий шаг, чтобы ввести записи Клиент и Перевозчик. Теперь, когда таблица Типы контактов содержит записи для поставщика, клиента и перевозчика, воспользуйтесь кнопками перехода внизу формы, чтобы просмотреть их. Щелкните затем на кнопке Закрыть (Close), чтобы закрыть форму Типы контактов. Важно. В большинстве компьютерных приложений необходимо сохранять результаты работы, чтобы не потерять их при зависании системы или сбое питания. В Access запись сохраняется автоматически, как только курсор перемещается в другую запись. Это означает, что можно не беспокоиться о потере данных - любое изменение является постоянным и может быть отменено только повторным редактированием записи. Щелкните на кнопке Переход в главную кнопочную форму. Щелкните на кнопке Ввод/просмотр формы "Контакты" чтобы отобразить форму Контакты.






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

Список содержит три типа контактов, которые вы ввели в таблицу Тип контакта.

Выделите один из типов контактов. Вернитесь на первую страницу, щелкните в поле Рабочий телефон, чтобы поместить в него курсор, введите 555-0100 и нажмите на клавишу (Enter). Снова щелкните в поле Рабочий телефон, а затем щелкните на кнопке Набрать номер. Появится диалоговое окно Автонабор (AutoDialer), где в качестве номера набора указан рабочий телефон. Совет. Данное диалоговое окно не является частью Access. Это утилита Windows, которая активизируется VBA-программой, связанной с кнопкой Набрать номер. Если щелкнуть на кнопке Настройка (Setup) появится диалоговое окно Параметры телефона и модема Windows (Windows Phone And Modem Options). (Если модем не установлен, появится диалоговое окно Установить модем (Install New Modem).) Щелкните на кнопке Отмена (Cancel), чтобы закрыть диалоговое окно Автонабор (AutoDialer), а затем щелкните на кнопке Переговоры чтобы отобразить форму Звонки.


увеличить изображение

Эта форма включает подчиненную форму Список звонков, в которой перечислены поступившие звонки, и подчиненную форму Заметки, содержащую заметки, относящиеся к выделенному звонку. Щелкните в ячейке Тема новой записи и введите Сведения о заказе.

Access добавит строку для новой записи, где полям Дата звонка и Время звонка по умолчанию присвоены текущие дата и время, как показано ниже.



Щелкните в поле Заметки, введите короткую заметку. Щелкните на кнопке Закрыть (Close), чтобы закрыть форму Звонки, а затем снова щелкните на кнопке Закрыть (Close), чтобы закрыть форму Контакты. Щелкните на кнопке Просмотр отчетов, чтобы отобразить кнопочную форму отчетов. Просмотрите два коротких отчета, щелкнув на соответствующей кнопке, прочитав отчет и закрыв его.



При попытке открыть отчет Просмотр отчета 'Звонки за неделю' появляется форма для ввода начальной и конечной даты. Если принять заданные по умолчанию значения (текущую неделю), в отчет будет включен только что введенный звонок.

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



Просмотрите все таблицы, формы и отчеты базы данных, щелкая на нужном типе на панели объектов, а затем открывая отдельные объекты. Форма Период отчета не может быть открыта из окна базы данных, поскольку она спроектирована таким образом, чтобы открываться VBA-программой. Закройте базу данных Контакты.

Создание базы данных простейшим способом


В недалеком прошлом разработка баз данных начиналась с подробного анализа потребностей пользователей и подготовки документации, определяющей структуру и содержание таблиц. Столь тщательная проработка объяснялась тем, что создание баз данных было делом трудоемким, а изменение структуры после ввода данных - достаточно сложным. Применение мастеров в корне изменило этот процесс. Структура базы данных не является теперь чем-то окончательным. С помощью мастера Создание баз данных (Database Wizard) можно создать несколько баз данных за то время, которое требовалось раньше на разработку одного лишь проекта. Хотя мастера Access не всегда создают то, что нужно, они создают нечто, весьма близкое, и очень быстро.

В этом упражнении вы воспользуетесь мастером, чтобы создать структуру базы данных, предназначенной для хранения сведений о контактах компании. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap10\CreatingDb. Выполните следующие шаги.

Если панель задачи Создание файла (New File) не отображается, откройте ее, щелкнув на кнопке Создать (New) на панели инструментов Access. На панели задачи в разделе Создание с помощью шаблона (New from template) щелкните на Общие шаблоны (General templates), а затем щелкните на вкладке Базы данных (Databases), чтобы отобразить следующие варианты.


Совет. Мастер Создание баз данных (Database Wizard) использует готовые шаблоны, позволяющие создавать довольно сложные базы данных. При наличии связи с Интернетом, помимо стандартных шаблонов Access, можно получить доступ к дополнительным шаблонам и другим ресурсам, воспользовавшись связью Шаблоны в Microsoft.com (Templates on Microsoft.com) в разделе Создать из шаблона (New from template) на панели задачи Создание файла (New File). Щелкните дважды на Контакты (Contact Management). Появится диалоговое окно Файл новой базы данных (File New Database), позволяющее ввести имя и расположение новой базы данных.


увеличить изображение



Совет. По умолчанию для хранения баз данных Access используется папка Мои документы (My Documents). Эту установку можно изменить, воспользовавшись диалоговым окном Параметры (Options), которое открывается из меню Сервис (Tools). На вкладке Общие (General) в поле Рабочий каталог (Default database Folder) введите путь к папке, которая будет использоваться по умолчанию, и щелкните на кнопке ОК. Перейдите к папке Office XP SBS\Access\Chap10\CreatingDb, которая является рабочей для данного упражнения, введите Контакты в поле Имя файла (File Name) и щелкните на кнопке Создать (Create). Совет. На имена баз данных Access накладываются те же ограничения, что и на имена других файлов Windows. То есть, имя файла может содержать не более 215 символов, включая пробелы. Запрещается использовать следующие символы: \ / : * ? " < > |. Базы данных Access имеют расширение .mdb.




Появится первая страница мастера Создание баз данных (Database Wizard), где описывается тип информации, которая будет храниться в базе данных. Поскольку эта страница не требует никакой реакции, щелкните на кнопке Далее (Next), чтобы перейти ко второй странице мастера.



В левой части страницы указаны три таблицы, входящие в базу данных, а в правом окошке перечислены поля, которые могут быть включены в эти таблицы. Обязательные поля помечены флажками, необязательные отображаются курсивом. Чтобы включить поле в таблицу, следует выделить соответствующий флажок. Поочередно щелкните на каждой таблице и просмотрите списки доступных полей. Щелкните на кнопке Далее (Next), чтобы включить все выделенные поля и перейти к следующей странице мастера. Третья страница мастера позволяет выбрать стиль оформления элементов базы данных. Совет. Если кнопка Назад (Back) доступна (не серая), можно, щелкнув на ней, вернуться к предыдущим страницам и изменить выбранные параметры. Если кнопка Готово (Finish) доступна, можно щелкнуть на ней, предоставив мастеру выполнить оставшиеся шаги самостоятельно. Если в результате получится не совсем то, чего вы хотели, не страшно. Большинство параметров базы данных можно модифицировать позже. Просмотрите все стили, щелкнув на каждом из них. Завершив просмотр стилей, щелкните на Диффузный (Blends) и щелкните на кнопке Далее (Next). Поочередно щелкните на каждом стиле оформления отчетов, чтобы просмотреть их, затем щелкните на Полужирный (Bold) и щелкните на кнопке Далее (Next). Замените предложенное имя базы данных на Контакты, очистите флажок Да, добавить рисунок во все отчеты (Yes I'd like to include picture) и щелкните на кнопке Далее (Next).

Поскольку это последняя страница мастера, кнопка Далее (Next) недоступна. По умолчанию выделен флажок Да, запустить базу данных (Yes, start the database) и очищен флажок Вывести справку по работе с базой данных (Display help on using a database).

Оставьте заданные по умолчанию установки без изменений и щелкните на кнопке Готово (Finish).



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


увеличить изображение

Щелкните на кнопке Закрыть (Close) в строке заголовка окна Главная кнопочная форма (Main Switchboard). В момент открытия главной кнопочной формы окно базы данных свернуто до укороченной строки заголовка, которая отображается в нижнем левом углу окна Access. Щелкните на кнопке Закрыть (Close) в конце строки заголовка, чтобы закрыть базу данных.

Лекция: Создание таблиц и работа с ними


Щелкните в поле ДомашнийТелефон, чтобы отобразить следующие свойства.

Хотя номер телефона состоит из цифр, он может также содержать тире, скобки и пробелы, поэтому тип данных для этого поля определен как Текстовый (Text). Как видите, текстовое поле имеет больше свойств, чем поле с типом данных Счетчик (AutoNumber).


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

В свойстве Подпись (Caption) указано значение Домашний Телефон. Это имя будет использоваться для заголовка столбца в режиме таблицы. Если вас не устраивают содержательные имена, предложенные мастером, их можно изменить.

Щелкните в поле ДатаНайма, чтобы отобразить его свойства, показанные ниже.


В свойстве Формат (Format) задано значение Краткий формат даты (Short Date). Это означает, что дата, введенная в любом стандартном формате, например, 10 апреля 2001, отобразится как 10.04.01.

Важно. В упражнениях этого курса, использующих краткий формат даты, предполагается, что задано двухразрядное отображение года (M/d/yy). Чтобы уточнить, какие установки заданы на вашем компьютере, откройте окно Панель управления (Control Panel), воспользовавшись подменю Настройка (Settings) в меню Пуск (Start), а затем щелкните дважды на Свойства региональных установок (Regional Settings Properties) в Windows 98 или Региональные параметры (Regional Options) в Windows 2000. В обоих случаях нужные установки представлены на вкладке Дата (Date).

Свойство Маска ввода (Input Mask) управляет вводом данных и форматом, в котором они хранятся. В маске 99/99/00;0 каждая "9" обозначает необязательную цифру, а цифра "0" - обязательную. В режиме таблицы эта маска отобразится следующим образом: "_/_/_". То есть, дата должна быть введена в формате 10/04/01, но сразу же после нажатия на клавишу (Enter) содержимое поля будет преобразовано к виду, определенному в свойстве Формат (Format).

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

Щелкните в поле свойства Условие на значение (Validation Rule) и введите <Now(). Затем щелкните в поле свойства Сообщение об ошибке (Validation Text) и введите Дата должна предшествовать сегодняшней. Это условие означает, что дата поступления на работу должна быть ранее (меньше) текущей, которая определяется функцией Now() на основании показаний компьютерных часов. Если введенная дата относится к будущему времени, ввод будет заблокирован и появится сообщение об ошибке. Важно. Свойства Формат (Format), Маска ввода (Input Mask) и Условие на значение (Validation Rule) позволяют уменьшить число ошибок при заполнении таблиц. Однако, применяя эти свойства, следует соблюдать меру, чтобы не слишком усложнить ввод данных. Поэтому, прежде чем передавать базу данных пользователям, рекомендуется тщательно протестировать заданные установки. Щелкните на кнопке Вид (View), чтобы вернуться в режим таблицы, и щелкните на кнопке Да (Yes) в ответ на предложение сохранить таблицу. Совет. При переключении из режима конструктора в режим таблицы (даже в том случае, если вы ничего не меняли) появляется окно сообщения, в котором предлагается сохранить изменения. Щелкнув на кнопке Нет (No), вы останетесь в режиме конструктора. Если щелкнуть на кнопке Да (Yes), Access сохранит изменения и переключится в режим таблицы. Чтобы не сохранять изменения (например, сделанные случайно), щелкните на кнопке Нет (No), а затем щелкните на кнопке Закрыть (Close) в окне таблицы. Когда появится окно сообщения, щелкните на кнопке Нет (No), чтобы закрыть таблицу без сохранения изменений.Попробуйте ввести будущую дату в оба поля: ДатаРождения и ДатаНайма. Вы сможете ввести дату в первое поле, но второе поле будет заблокировано из-за условия, наложенного на значение, и появится сообщение об ошибке. Щелкните на кнопке ОК в окне сообщения, измените значение в поле ДатаНайма на дату, предшествующую текущей, а затем щелкните на кнопке Закрыть (Close), чтобы закрыть таблицу Сотрудники. В окне базы данных выделите таблицу Поставщики и щелкните на кнопке Конструктор (Design), чтобы открыть таблицу в режиме конструктора. Щелкните дважды на имени поля ОбластьКрайРеспублика, чтобы выделить его, и введите Штат. Затем в разделе Свойства поля (Field Properties) щелкните в поле свойства Подпись (Caption) и тоже введите Штат. Удалите поля Страна, УсловияОплаты, АдресЭлектроннойПочты и Заметки, щелкая на селекторе строки и нажимая на клавишу (Del). Совет. При удалении поля появится предупреждение, что требуется удалить все индексы. Щелкните на кнопке Да (Yes). (В шаге 19 также щелкните на кнопке Да (Yes) в ответ на аналогичное сообщение.) Щелкните на кнопке Закрыть (Close), чтобы закрыть таблицу Поставщики и щелкните на кнопке Да (Yes), чтобы сохранить изменения. Откройте таблицу Клиенты в режиме конструктора и удалите следующие поля: НазваниеКомпании, ОрганизацияИлиОтдел, ДолжностьПолучателя, Внутренний, Факс, АдресЭлектроннойПочты и Заметки. Щелкните в поле КодКлиента и введите 5 в поле свойства Размер поля (Field Size). Замените подписи к следующим полям: ИмяКонтакта на Имя, ФамилияКонтакта на Фамилия, АдресВыставленияСчета на Адрес, ОбластьКрайРеспублика на Регион, Страна/регион на Страна. Щелкните на кнопке Закрыть (Close), чтобы закрыть таблицу Клиенты. Закройте базу данных GardenCo.



Операции над столбцами и строками таблицы


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

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

GardenCo

В этом упражнении вы откроете таблицу и выполните действия над столбцами и строками. Для большей наглядности вы будете работать с версией базы данных GardenCo, которая содержит несколько таблиц с большим числом записей. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap10 \Manipulate. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на пункте Таблицы (Tables). Щелкните дважды на таблице Клиенты, чтобы открыть ее в режиме таблицы. Перетащите правую границу заголовка столбца Адрес влево, чтобы сузить его до 1 см.


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


В меню Формат (Format) щелкните на команде Высота строки (Row Height), чтобы открыть одноименное диалоговое окно. Выделите флажок Стандартная (Standard Height) и щелкните на кнопке ОК. Высота всех строк вернется к заданному по умолчанию значению. (Это диалоговое окно позволяет также задать точное значение высоты строки.) Щелкните в столбце Имя, а затем щелкните на команде Скрыть столбцы (Hide Columns) в меню Формат (Format). Столбец исчезнет, а следующие за ним столбцы сдвинутся влево. Если, прежде чем щелкнуть на команде Скрыть столбцы (Hide Columns), выделить несколько столбцов, исчезнут все выделенные столбцы. Совет. Можно выделить несколько смежных столбцов, если щелкнуть на заголовке первого из них и, нажав на клавишу (Shift), щелкнуть на заголовке последнего.Чтобы вернуть на экран скрытые столбцы, щелкните на команде Отобразить столбцы (Unhide Columns) в меню Формат (Format). Выделите флажок Имя, а затем щелкните на кнопке Закрыть (Close). Столбец Имя снова появится на экране. Перетащите правую границу окна базы данных влево. Окно сузится, и часть полей окажется за пределами видимости. Укажите на заголовок столбца Код Клиента и, нажав на кнопку мыши, протащите указатель по заголовкам столбцов Имя и Фамилия. Выделив таким образом три столбца, щелкните на команде Закрепить столбцы (Freeze Columns) в меню Формат (Format). Если теперь прокрутить окно вправо, закрепленные столбцы останутся на месте. В меню Формат (Format) щелкните на команде Освободить все столбцы (Unfreeze All Columns), чтобы вернуть столбцы в исходное состояние. Закройте таблицу без сохранения изменений, а затем закройте базу данных GardenCo.



Совершенствование отображения данных в таблице


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

Значения свойств, заданные Access, в большинстве случаев являются оптимальными и не нуждаются в модификации. Однако если некоторые свойства вас не устраивают, их можно легко изменить. Изменение одних свойств не влияет на содержимое таблицы, изменение других может вызвать нежелательные последствия. Поэтому, пока вы не наберетесь опыта работы в Access, следует проявлять определенную осторожность при изменении свойств полей.

GardenCo

В этом упражнении вы просмотрите и отредактируете свойства полей одной из таблиц базы данных GardenCo, расположенной в папке Office XP SBS\Access\Chap10\Refining, являющейся рабочей для этого упражнения. Выполните следующие шаги:

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


Размер окна таблицы на вашем экране может отличаться от приведенного на рисунке. Обратите внимание, что имена полей, состоящие из двух слов, включают пробелы, в отличие от полей созданных с помощью мастера. Совет. Как и в других приложениях Microsoft Office ХР, размер окна можно изменить. Поместите указатель в угол окна и, когда он примет форму двунаправленной стрелки, перетащите его, чтобы увеличить или уменьшить окно.Щелкните на кнопке Вид (View), чтобы отобразить таблицу в режиме Конструктор (Design), как показано ниже.


увеличить изображение

В режиме конструктора верхняя часть окна содержит список полей таблицы. В столбце Имя поля (Field Name) указаны имена полей, выбранных при создании таблицы. Обратите внимание, что они не содержат пробелов. В столбце Тип данных (Data Type) указан тип данных, содержащихся в поле. В столбце Описание (Description) представлено краткое описание каждого поля.

Обратите внимание на значок ключевого поля слева от поля КодСотрудника. Это поле используется для идентификации записей таблицы (то есть, в таблице не должно быть двух или более записей, имеющих одинаковое значение в ключевом поле). Если ключевое поле имеет тип данных Счетчик (AutoNumber), уникальность ключа обеспечивается автоматически. При добавлении новой записи Access заполняет это поле, увеличивая текущее значение счетчика на единицу.

Совет. Если ключевое поле более не требуется, выделите его в верхней части окна и щелкните на команде Ключевое поле (Primary Key) в меню Правка (Edit). Чтобы сделать ключевым другое поле, выделите его и щелкните на команде Ключевое поле (Primary Key) в меню Правка (Edit) Щелкните в ячейке Тип данных (Data Type) для поля КодСотрудника, а затем щелкните на стрелке, которая появится.




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

Совет. Чтобы получить сведения обо всех типах данных, обратитесь к теме "Тип данных (Data Type)" в справочной системе Access. Нажмите на клавишу (Esc), чтобы закрыть список, не меняя типа данных. Щелкните в каждом поле в разделе Свойства поля (Field Properties) внизу окна таблицы. Количество свойств, приведенных в разделе Свойства поля (Field Properties), зависит от типа данных. Например, типу Счетчик (AutoNumber) соответствуют пять свойств, причем четыре свойства снабжены списками для выбора нужной установки. Если щелкнуть на свойстве, в пустой области справа появится его описание, как показано на следующем рисунке.



Свойство Размер поля (Field Size) определяет размер или величину значений, которые могут быть введены в это поле. Например, поле, имеющее тип данных Длинное целое (Long Integer), может содержать целые числа в интервале от - 2147483648 до 2147483647. Если задан тип данных Счетчик (AutoNumber), поле может содержать только целые значения, начиная с 1, что позволяет ввести более двух миллиардов записей, не опасаясь переполнения.

Список свойства Новые значения (New Values) содержит два элемента: Случайные (Random) и Последовательные (Increment). Последняя установка означает, что при добавлении новой записи полю будет присвоено очередное значение из последовательности целых чисел.

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

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

Установка Да, совпадения не допускаются (Yes (No Duplicates)) для свойства Индексированное (Indexed) означает, что данные в поле проиндексированы для ускорения поиска, но ввод повторяющихся значений запрещен. Для ключевого поля эта установка принимается по умолчанию.

Совет. Для получения дополнительной информации об определенном свойстве щелкните на нем и нажмите на клавишу (F1), чтобы отобразить справку Access. С выделенным полем КодСотрудника (выделенное поле помечено стрелкой в селекторе строки) щелкните на свойстве Формат (Format), а затем введите три нуля (000).



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

Щелкните в поле Фотография и замените тип данных с Поле объекта OLE (OLE Object) на Текстовый (Text).

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

Создание таблиц простейшим способом


База данных, созданная с помощью мастера Создание баз данных (Database Wizard), имеет все компоненты, необходимые для хранения основных сведений о контактах. Предположим, однако, что компания "Все для сада" хотела бы хранить различные сведения для разных типов контактов. Например, помимо стандартной информации (именам, адресам и телефонам), компания хотела бы располагать следующими данными:

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

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

Поскольку мастер Создание баз данных (Database Wizard) не обеспечивает подобную комбинацию, в этом упражнении вы создадите базу данных GardenCo, начав с пустой структуры, а затем добавите в нее несколько таблиц с помощью функции Мастер таблиц (Table Wizard). В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap10\CreatingDb. Выполните следующие шаги.

На панели инструментов щелкните на кнопке Создать (New), чтобы отобразить панель задачи Создание файла (New File). На панели задачи в разделе Создание (New) щелкните на кнопке Новая база данных (Blank Database). Перейдите к папке Office XP SBS\Access\Chap10\CreatingDb, введите GardenCo в качестве имени базы данных и щелкните на кнопке Создать (Create).

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

На панели инструментов окна базы данных щелкните на кнопке Создать (New), чтобы отобразить диалоговое окно Новая таблица (New Table). Совет. Вместо кнопки Создать (New) можно воспользоваться кнопкой Новый объект (New Object), щелкнув на стрелке, а затем щелкнув на Таблица (Table). Можно также щелкнуть на пункте Таблица (Table) на панели объектов, а затем щелкнуть дважды на команде Создание таблицы с помощью мастера (Create table by using wizard) или воспользоваться командой Таблица (Table) в меню Вставка (Insert). Щелкните дважды на пункте Мастер таблиц (Table Wizard), чтобы отобразить первую страницу мастера, показанную ниже.






В поле Образцы таблиц (Sample Tables) можно отобразить две категории таблиц. Хотя эти категории ориентированы на деловые и личные нужды, нужная таблица может оказаться в любом из списков. Просмотрите список деловых таблиц, а затем щелкните на варианте Личные (Personal) и просмотрите список личных таблиц.

Если щелкнуть на элементе списка Образцы таблиц (Sample Tables) в списке Образцы полей (Sample Fields) отобразятся все поля, доступные для этой таблицы. Чтобы переместить поле из списка Образцы полей (Sample Fields) в список Поля новой таблицы (Fields in my new table), нужно выделить его, а затем щелкнуть на кнопке >. Кнопка >> позволяет переместить сразу все образцы полей в новую таблицу. Кнопки < и << удаляют одно или все поля из новой таблицы. После завершения работы мастера можно добавить в таблицу новые поля или удалить лишние.

Выделив вариант Деловые (Business), выделите элемент Клиенты в списке Образцы таблиц (Sample Tables). Щелкните на кнопке >>, чтобы скопировать все поля выделенной таблицы в список Поля новой таблицы (Fields in my new table), а затем щелкните на кнопке Далее (Next), чтобы перейти к следующей странице мастера.

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

Оставьте Клиенты в качестве имени таблицы без изменений, выделите вариант Пользователь определяет ключ самостоятельно (No, I'll set the primary key) и щелкните на кнопке Далее (Next). Мастер предложит поле КодКлиента в качестве ключа и спросит, какие данные должны содержаться в ключевом поле. Щелкните на варианте Сочетание чисел и букв, вводимое пользователем при добавлении новых записей (Numbers and/or letters I enter when I add new records), а затем щелкните на кнопке Далее (Next), чтобы перейти к следующей странице мастера. Мастер предлагает три варианта открытия таблицы: в режиме конструктора, в режим таблицы или в виде созданной мастером формы, предназначенной для ввода данных. Примите выделенный по умолчанию вариант Ввести данные непосредственно в таблицу (Enter data directly into table) и щелкните на кнопке Готово (Finish), чтобы мастер мог создать и открыть таблицу Клиенты. Прокрутите таблицу по горизонтали, чтобы просмотреть все поля, созданные мастером, а затем закройте таблицу. В окне базы данных появится новая таблица Клиенты. Снова запустите Мастер таблиц (Table Wizard), на этот раз щелкнув на команде Создание таблицы с помощью мастера (Create table by using wizard) в окне базы данных. В списке Образцы таблиц (Sample Tables) выделите Сотрудники и переместите в список Поля новой таблицы (Fields in my new table) следующие поля, выделяя каждое поле и щелкая на кнопке >.



КодСотрудника

Имя

Фамилия

Должность

Адрес

Город

ОбластьКрайРеспублика

ПочтовыйИндекс

ДомашнийТелефон

ДатаРождения

ДатаНайма

Фотография

Заметки

В списке Поля новой таблицы (Fields in my new table) выделите ОбластьКрайРеспублика, щелкните на кнопке Переименовать поле (Rename Field), введите Область и щелкните на кнопке ОК. Щелкните на кнопке Далее (Next) два раза подряд, чтобы переместиться на две страницы вперед, приняв предложенное название таблицы и разрешив Access создать ключ. Поскольку в базе данных уже существует одна таблица, мастер попытается установить между ними связь. Так как связь можно установить позже, щелкните на кнопке Далее (Next), чтобы перейти к следующей странице мастера. Щелкните на кнопке Готово (Finish), а затем закройте таблицу Сотрудники. Повторите шаги 13-18, чтобы создать базу данных Поставщики, включив в нее все доступные поля. Щелкните на кнопке Готово (Finish), чтобы принять все предложения, заданные по умолчанию. Закройте таблицу Поставщики. Теперь в окне базы данных отображаются три таблицы. Закройте базу данных.

Изменение свойств формы


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

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

GardenCo tgs_bkgrnd

В этом упражнении вы измените свойства формы Клиенты в соответствии с нуждами пользователей, которые с ней ежедневно работают. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap11\Properties. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.На панели объектов выделите пункт Формы (Forms), в списке форм выделите Клиенты и щелкните на кнопке Конструктор (Design). Форма откроется в режиме конструктора, как показано на следующем рисунке.


увеличить изображение

Форма наследует многие свойства таблицы, на основе которой она создается. В данном случае имена полей формы являются именами полей таблицы, надписи к полям задаются свойством Подпись (Caption), а размер полей определяется свойством Размер поля (Field Size).

Совет. Свойства формы не привязаны к исходной таблице. Изменение свойств таблицы не влияет на соответствующие свойства формы, и наоборот. Измените шрифт надписи Код клиента, щелкнув на ней, а затем щелкнув на Microsoft Sans Serif в списке Шрифт (Font) на панели инструментов Форматирование (Formatting). (Если в списке нет этого шрифта, воспользуйтесь другим, например, MS Sans Serif.)В списке Размер шрифта (Font Size) щелкните на значении 8, чтобы немного уменьшить шрифт выделенной надписи.Щелкните правой кнопкой мыши в поле КодКлиента и щелкните на команде Свойства (Properties) в контекстном меню, чтобы отобразить диалоговое окно свойств этого поля.






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

Свойства элементов формы сгруппированы по вкладкам Макет (Format), Данные (Data), События (Event) и Другие (Other). Чтобы отобразить все свойства, откройте вкладку Все (All).

Щелкните на вкладке Макет (Format), прокрутите список свойств до Шрифт (Font Name) и установите шрифт Microsoft Sans Serif (или MS Sans Serif). Затем в поле свойства Размер шрифта (Font Size) установите значение 8, а в поле свойства Насыщенность (Font Weight) - Полужирный (Bold). Все изменения свойств поля КодКлиента тут же отображаются в форме. Совет. Если диалоговое окно Свойства (Properties) закрывает обзор, можно перетащить его к краю экрана, чтобы наблюдать за изменениями в форме.Щелкните на стрелке поля вверху диалогового окна Свойства (Properties), а затем щелкните на Имя_Надпись в списке, чтобы выделить надпись слева от поля Имя.Повторите шаг 6, чтобы изменить установки шрифта для этого элемента управления. Хотя изменение свойств элемента управления осуществляется легко и просто, модификация нескольких дюжин элементов может оказаться утомительным занятием. Следующие два шага показывают, как сразу изменить свойства нескольких элементов.Нажмите на клавиши (Ctrl)+(A) чтобы выделить все элементы управления в разделе Область данных (Detail). Совет. Можно также выделить все элементы формы, щелкнув на команде Выделить все (Select All) в меню Правка (Edit) или протащив указатель по форме таким образом, чтобы заключить в прямоугольную рамку нужные элементы.

Вокруг всех элементов управления появятся черные квадратики, называемые рукоятками. В строке заголовка диалогового окна Свойства (Properties) теперь указано "Несколько элементов управления (Multiple Selection)", а список объектов пустой. На вкладке Макет (Format) отображаются только те установки, которые имеют одинаковые значения для всех выделенных элементов. Поскольку изменения, выполненные в предыдущих шагах, распространяются не на все выделенные элементы, свойства Шрифт (Font Name), Размер шрифта (Font Size) и Насыщенность (Font Weight) не имеют значений.

Чтобы применить новые установки ко всем выделенным элементам управления, повторите действия, выполненные в шаге 6.На вкладке Макет (Format) щелкните на свойстве Тип фона (Back Style) и выберете значение Обычный (Normal). Фон надписей больше не является прозрачным.Щелкните на свойстве Цвет фона (Back Color), а затем щелкните на кнопке построителя ... в конце поля, чтобы отобразить диалоговое окно Цвет (Color).





Щелкните на бледно-желтом цвете и щелкните на кнопке ОК. Фон всех элементов управления станет бледно-желтым. Совет. Если на палитре нет нужного цвета, щелкните на кнопке Определить цвет (Define Custom Colors), подберите параметры, чтобы добиться желаемого оттенка, и щелкните на кнопке Добавить в набор (Add to Custom Colors).В списке свойства Оформление (Special Effects) щелкните на С тенью (Shadowed), а затем задайте зеленый цвет для свойства Цвет границы (Border Color).

Задавая цвет, можно воспользоваться кнопкой построителя : и выбрать нужный оттенок или ввести числовое обозначение цвета (например, 32768) в поле свойства Цвет границы (Border Color).

Щелкните в разделе Область данных (Detail), чтобы отменить выделение. Форма должна теперь выглядеть примерно так.


увеличить изображение

Щелкните на надписи слева от поля FirstName Почтовый Индекс, а затем в диалоговом окне Свойства (Properties) установите в свойстве Подпись (Caption) значение Индекс.Повторите шаг 16, чтобы заменить текст надписи Номер Телефона на Телефон. Совет. Значения свойств Подпись (Caption) и Данные (Control Source) можно отредактировать обычным способом, выделив содержимое поля и введя нужный текст. Однако в последнем случае следует соблюдать осторожность, поскольку это свойство определяет источник, откуда поступают данные.Удалите надпись слева от поля Фамилия, щелкнув на ней и нажав на клавишу (Del).Выделите все надписи (но не соответствующие им поля), щелкая на каждой из них при нажатой клавише (Shift). Затем в диалоговом окне Свойства (Properties) в поле свойства Выравнивание текста (Text Align) установите значение По правому краю (Right).В меню Формат (Format) укажите на команду Размер (Size), а затем щелкните на По размеру данных (To Fit), чтобы подогнать размеры надписей под длину содержащегося в них текста, как показано ниже.


увеличить изображение

Совет. Если в процессе форматирования, аналогичного приведенному выше, вы получили не тот результат, на который рассчитывали, щелкните на кнопке Восстановить (Undo) или нажмите на клавиши (Ctrl)+(Z), чтобы отменить последние изменения, и повторите попытку.Выделите теперь все поля (но не надписи к ним), а затем в диалоговом окне Свойства (Properties) в поле свойства От левого края (Left) введите значение 4 см, чтобы создать небольшой промежуток между надписями и полями.В поле свойства Насыщенность (Font Weight) установите значение Обычный (Normal), а затем щелкните вне элементов управления, чтобы отменить выделение.Чтобы внешний вид формы соответствовал принятому в компании, в списке объектов вверху диалогового окна Свойства (Properties) выделите Форма (Form). Щелкните на свойстве Рисунок (Picture), а затем щелкните на кнопке построителя :, чтобы отобразить диалоговое окно Выбор рисунка (Insert Picture).Перейдите к папке Office XP SBS\Access\Chap11\Properties, в поле Тип файлов (Files of Type) установите значение Графические файлы (Graphic Interchange Format), а затем щелкните дважды на файле tgc_bkgrnd. Фон формы изменится, а в поле свойства Рисунок (Picture) отобразится путь к выбранному файлу.Щелкните на кнопке Сохранить (Save), чтобы сохранить макет формы Клиенты.Закройте форму и базу данных.


Создание формы с помощью мастера


Прежде чем приступать к созданию формы, нужно решить, на какой таблице она базируется и для каких целей предназначена. Решив эти вопросы, можно создать форму, воспользовавшись мастером Создание формы (Form Wizard). Если созданная мастером форма не совсем отвечает вашим нуждам, ее можно модифицировать в режиме конструктора, как и большинство объектов Access.

GardenCo

В этом упражнении вы создадите форму, предназначенную для ввода информации о клиентах в таблицу Клиенты базы данных GardenCo. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap11\FormByWiz. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.На панели объектов щелкните на пункте Формы (Forms).Щелкните дважды на команде Создание формы с помощью мастера (Create form by using wizard), чтобы запустить мастер Создание формы (Form Wizard), первая страница которого имеет следующий вид.


В списке Таблицы и запросы (Table/Query) щелкните на Таблица: Клиенты (Table: Customers), чтобы отобразить поля этой таблицы в списке Доступные поля (Available Fields).Щелкните на кнопке >>, чтобы переместить все поля таблицы Клиенты в список Выбранные поля (Selected Fields), и щелкните на кнопке Далее (Next). Вторая страница мастера позволяет выбрать внешний вид формы. Если щелкнуть на одном из вариантов, представленных справа, в левой части страницы отобразится соответствующий макет.Щелкните на варианте В один столбец (Columnar), а затем щелкните на кнопке Далее (Next). Появится страница, позволяющая выбрать стиль оформления формы. Каждый стиль можно просмотреть на образце, выделив его в списке. Выделите стиль Рисунок Суми (Sumi Painting) и щелкните на кнопке Далее (Next).Так как форма базируется на таблице Клиенты, Access предлагает имя таблицы в качестве заголовка формы. Примите предложение, оставьте выделенным флажок Открыть форму для просмотра и ввода данных (Open the form to view or enter information) и щелкните на кнопке Готово (Finish).

Откроется новая форма Клиенты, в которой отображается первая запись таблицы Клиенты.


Воспользуйтесь кнопками перехода внизу формы, чтобы просмотреть несколько записей.Закройте форму и базу данных.



Улучшение макета формы


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

В процессе работы над формой указатель принимает вид, отображающий тип действия, которое можно выполнить в данный момент. Это тем более важно, что надпись и поле трактуются иногда как единый объект, что может привести к нежелательным изменениям. В следующей таблице представлены типы указателей и действия, которые они выполняют:

Форма указателяДействие
РукаПеретаскивает оба элемента управления как один объект.
Указывающий палецПеретаскивает один элемент управления
Вертикальные стрелкиПеретаскивает верхнюю или нижнюю границу, чтобы изменить высоту элемента управления.
Горизонтальные стрелкиПеретаскивает правую или левую границу, чтобы изменить ширину элемента.
Диагональные стрелкиПеретаскивает угол элемента управления, чтобы изменить высоту и ширину одновременно.
GardenCo

В этом упражнении вы упорядочите элементы управления в форме Клиенты, чтобы последовательность полей ввода соответствовала порядку заполнения формы. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap11\Layout. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.Откройте форму Клиенты в режиме Конструктор (Design).Если нужно, перетащите правый нижний угол окна формы вниз и вправо, чтобы отобразить всю форму и пустую область справа, как показано на следующем рисунке.


увеличить изображение

Форма состоит из трех разделов: Заголовок формы (Form Header), Область данных (Detail) и Примечание формы (Form Footer).

На данном этапе только область данных имеет содержимое.

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




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



Совет. Чтобы точно разместить элемент управления, щелкните на нем, переместите указатель по элементу, так чтобы он принял нужную форму, а затем передвиньте элемент с помощью клавиш-стрелок. Каждое нажатие смещает выделенный элемент на небольшое расстояние в направлении, указанном стрелкой.В меню Формат (Format) щелкните на команде Автоформат (AutoFormat), чтобы отобразить диалоговое окно Автоформат (AutoFormat).



Щелкните на кнопке Настройка (Customize), чтобы отобразить диалоговое окно Настройка автоформата (Customize AutoFormat).Выделите вариант Создание нового стиля на основе формы 'Клиенты' (Create a new AutoFormat based on the form 'Customers') и щелкните на кнопке ОК.В диалоговом окне Новое название стиля (New Style Name) введите The Garden Company и щелкните на кнопке ОК.

В диалоговом окне Автоформат (AutoFormat) в списке автоформатов появится новый стиль. Он доступен для любой базы данных, открытой на вашем компьютере.

Щелкните на кнопке ОК, чтобы закрыть диалоговое окно Автоформат (AutoFormat).Щелкните на кнопке Сохранить (Save).Закройте форму и базу данных.

Добавление элементов управления в форму


Каждая форма имеет три основных раздела: Заголовок формы (Form Header), Область данных (Detail) и Примечание формы (Form Footer). При создании формы мастер добавляет в область данных элементы управления для каждого поля, выбранного в базовой таблице, оставляя разделы заголовка и примечания пустыми. Пустые разделы свернуты, но их можно развернуть, перетащив селекторы. Хотя наиболее распространенными элементами управления, которые встречаются в формах, являются надписи и поля, существуют и другие типы элементов, повышающие эффективность ввода информации. Например, можно добавить в форму флажки, кнопки выбора и поля со списками, чтобы выбирать значения, а не вводить их вручную.

Большинство элементов управления хранится на панели элементов. Щелкнув на кнопке Другие элементы (More Controls), можно отобразить список дополнительных элементов, которые Access обнаружил на вашем компьютере. При этом необязательно, чтобы дополнительные элементы имели отношение к Access или, вообще, к приложениям Microsoft Office.

Важно. Среди элементов управления есть очень эффективные, как, например, Календарь (Calendar), но есть и такие, которые могут привести к неприятным сюрпризам. Поэтому, если база данных содержит важные сведения, лучше воздержаться от экспериментов. GardenCo, tgc_logo2

В этом упражнении вы добавите в раздел заголовка формы Клиенты рисунок и название, а затем замените элемент управления поле Страна на поле со списком. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap11\Controls. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.Откройте форму Клиенты в режиме Конструктор (Design).Укажите на горизонтальную линию между селекторами разделов Заголовок формы (Form Header) и Область данных (Detail) и, когда указатель примет форму двуглавой стрелки, перетащите селектор области данных вниз на 2,5 см. Форма будет выглядеть, как показано на следующем рисунке.


увеличить изображение

Если панель элементов отсутствует на экране, щелкните на кнопке Панель элементов (Toolbox) на панели инструментов. Можно также воспользоваться командой Панель элементов (Toolbox) в меню Вид (View). Чтобы панель элементов не закрывала форму, можно прикрепить ее к одному из краев экрана.Чтобы получить представление о доступных элементах управления, поочередно поместите указатель на каждую кнопку на панели элементов и прочитайте экранные подсказки.Щелкните на элементе Рисунок (Image), щелкните в левой части заголовка и протащите указатель по форме, чтобы начертить прямоугольник высотой в 2,5 см и шириной в 7,5 см. Отпустите кнопку мыши. Появится диалоговое окно Выбор рисунка (Insert Picture), позволяющее выбрать графический файл, который будет вставлен в элемент управления.Убедитесь, что открыта папка Office XP SBS\Access\Chap11\Controls, а поле Тип файлов (Files of Type) содержит значение Графические файлы (Graphic Interchange Format). Щелкните дважды на файле tgc_logo2. Внутри элемента управления появится логотип компании, как показано ниже.






Совет. Если элемент управления слишком мал, рисунок будет обрезан. Чтобы отобразить рисунок полностью, увеличьте элемент управления. (Возможно, придется также увеличить область заголовка.)Чтобы ввести заголовок формы, на панели элементов щелкните на элементе управления Надпись (Label), щелкните справа от логотипа компании и протащите указатель, чтобы начертить прямоугольник. В области заголовка формы появится элемент управления надпись, содержащий курсор.Введите Клиенты и нажмите на клавишу (Enter). Вставленный заголовок отформатирован так же, как и остальные надписи.Нажмите на клавишу (F4), чтобы отобразить диалоговое окно Свойства (Properties) для выделенной надписи.В поле свойства Размер шрифта (Font Size) введите 18, в поле свойства Выравнивание текста (Text Align) установите значение По центру (Center) и закройте диалоговое окно свойств.В меню Формат (Format) укажите на команду Размер (Size) и щелкните на По размеру данных (To Fit).Отрегулируйте размер и положение двух новых элементов управления в соответствии со следующим рисунком.



Использование VBA для ввода данных в форму


Как вы уже, наверное, поняли, почти все в Access является объектом. Одной из особенностей объектов является их способность распознавать события, представляющие собой некие действия, и реагировать на них. Практически все объекты распознают щелчки, двойные щелчки и перемещение мыши. Помимо этого, большинство объектов распознают и другие события. Так, например, элемент управления поле распознает 17 событий, а форма - более 50.

Совет. Список событий, распознаваемых объектом, отображается на вкладке Событие (Event) диалогового окна Свойства (Properties).

При работе с формой объекты практически постоянно сигнализируют события. Часть событий Access обрабатывает, но большинство игнорирует. Для событий, которые Access распознает, но не обрабатывает, можно указать действие, которое следует выполнить после наступления данного события (например, запустить макрос, решающий определенную задачу).

Все это звучит довольно сложно. К тому же события не относятся к числу понятий, о которых задумывается обычный пользователь. Тем не менее стоит уделить им внимание, если вас интересует, что происходит при вводе данных и как добиться большей эффективности объектов формы.

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

GardenCo, AftUpdate

В этом упражнении вы напишете небольшую VBA-программу и свяжете ее с событием После обновления (After Update) в поле Фамилия формы Клиенты. Если изменить содержимое поля и попытаться перейти к другому элементу формы, генерируется событие Перед обновлением (Before Update). Access реагирует на это событие, обновляя запись в исходной таблице, после чего генерируется событие После обновления (After Update), обработкой которого вы и займетесь. Это упражнение не является глубоким погружением в Visual Basic, но дает представление о его возможностях. В качестве рабочей папки будет использоваться Office XP SBS\Access\Chap11\Events. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.На панели объектов выделите Формы (Forms), в списке форм щелкните на Клиенты, а затем щелкните на кнопке Конструктор (Design).Щелкните на поле Фамилия, чтобы выделить его, и откройте диалоговое окно Свойства (Properties), нажав на клавишу (F4).Щелкните на вкладке Событие (Event), чтобы отoбразить следующий список.






На вкладке представлены события, на которые может реагировать элемент управления Фамилия.Щелкните на событии После обновления (After Update), а затем щелкните на кнопке построителя :. Появится диалоговое окно Построитель (Choose Builder), в котором предлагается построить выражение, макрос или программу.Щелкните на Программы (Code Builder) и щелкните на кнопке ОК, чтобы открыть окно редактора Visual Basic, показанное ниже.


увеличить изображение

На панели Проект (Project Explorer) перечислены все созданные вами объекты, с которыми можно связать программу. В данном случае это форма Клиенты. По мере создания других форм и отчетов на панели будут появляться соответствующие объекты.

В окне программы отображается процедура Private Sub Фамилия_AfterUpdate , которая будет использоваться для обработки события После обновления (After Update) в поле Фамилия. На данном этапе она состоит только из двух утверждений, определяющих ее начало (Sub) и конец (End Sub) .

Введите следующие строки между операторами Sub и End Sub (или скопируйте их из файла AftUpdate в папке Office XP SBS\Access\Chap11\Events). 'Создайте переменные для Имени, Фамилии 'и Кода клиента Dim fName As String Dim lName As String Dim cID As String 'Присвойте значения переменной lName из текстового 'поля Фамилия. 'lName = Forms!клиенты!Фамилия.Text 'Вы должны активизировать текстовое поле прежде, 'чем прочитать его содержание. Forms!клиенты!Имя.SetFocus fName = Forms!клиенты!Имя.Text 'Объедините части Фамилии и Имени 'для создания Кода клиента. cID = UCase(Left(lName, 3) & Left(fName, 2)) 'Не храните Код, если только это не 5 знаков. '(Это означает, что оба имени заполнены.) If Len(cID) = 5 Then Forms!клиенты!КодКлиента.SetFocus 'Не изменяйте Код, если он уже был введен. 'Возможно, это было сделано вручную. If Forms!клиенты!КодКлиента.Text = "" Then Forms!клиенты!КодКлиента = cID End If End If 'Активизировать поле ввода Адреса. Forms!клиенты!Адрес.SetFocus

Важно. Строки, начинающиеся с кавычки, являются комментариями (пояснениями) к следующему за ними фрагменту программы. В редакторе Visual Basic комментарии отображаются зеленым цветом.Сохраните файл, щелкните на кнопке View Microsoft Access, чтобы вернуться в окно Access, и закройте окно Свойства (Properties).В режиме формы, если нужно, измените размер окна. Затем на панели перехода щелкните на кнопке Новая запись (New Record), чтобы создать новую запись.Нажмите на клавишу (Tab), чтобы переместить курсор в поле Имя, введите Джим, нажмите на клавишу (Tab), чтобы перейти в поле Фамилия, введите Патерсон и снова нажмите на клавишу (Tab). Если вы не сделали ошибки при вводе VBA-программы, в поле КодКлиента появится значение ПАТДЖ.Измените имя или фамилию клиента. Обратите внимание, что значение в поле КодКлиента не меняется даже при изменении имен, на основании которых оно образовано.Нажмите на клавишу (Esc), чтобы очистить поля, и попытайтесь вначале ввести фамилию, а потом имя. Значение КодКлиента не будет сформировано, поскольку подобная ситуация не предусмотрена в VBA-программе. Чтобы обеспечить создание кода клиента независимо от последовательности заполнения полей формы, нужно написать аналогичную процедуру для поля Имя или написать одну процедуру, обрабатывающую событие После обновления (After Update) для обоих полей. Такая процедура содержится в базе данных, которая используется в следующем упражнении, и при желании ее можно просмотреть.Нажмите на клавишу (Esc), чтобы очистить поля, а затем закройте форму Клиенты и базу данных.Нажмите на клавиши (Alt) + (Tab), чтобы переключиться в редактор VBA, и закройте его.


Лекция: VBA, функция Автоформа и добавление элементов управления в форму


Если на панели элементов кнопка Мастера (Control Wizard) активна (имеет рамку), щелкните на ней, чтобы отключить. Отключение кнопки мастеров позволяет создавать элементы управления с заданными по умолчанию установками, не выполняя шаги мастера.Вставьте поле со списком в область данных. Для этого щелкните на элементе управления Поле со списком (Combo Box), а затем протащите указатель по форме, так чтобы начертить прямоугольник прямо под полем Страна. В форме появится поле со списком, которое является свободным, то есть, не привязанным к полям таблицы Клиенты.Примените форматирование поля Страна к новому элементу управления. Для этого щелкните на поле Страна, щелкните на кнопке Форматирование по образцу (Format Painter) на панели инструментов, а затем щелкните на новом поле со списком. Поле со списком и надпись к нему приобретут такой же вид, как и другие элементы формы.Снова выделите поле со списком и отобразите диалоговое окно Свойства (Properties).Щелкните на вкладке Данные (Data), в свойстве Данные (Control Source) укажите Страна, а затем введите следующий текст в поле свойства Источник строк (Row Source):

SELECT DISTINCT Клиенты.Страна FROM Клиенты;

(Между Клиенты и Страна нет пробела, только точка.)

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


Совет. Если нужно добавить клиента из страны, которой нет в списке, введите новую страну в поле со списком. После добавления записи в таблицу, эта страна будет отображаться в списке.В поле свойства Тип источника строк (Row Source Type) укажите Таблица или запрос (Table/Query).Щелкните на надписи слева от поля со списком, в диалоговом окне щелкните на вкладке Макет (Format) и введите Страна в поле свойства Подпись (Caption). Закройте диалоговое окно Свойства (Properties). Удалите исходное поле Страна с надписью, а затем переместите на его место новое поле со списком и его надпись. Если нужно отрегулируйте размеры полей. Щелкните на кнопке Вид (View), чтобы отобразить форму, которая должна выглядеть примерно так:



Создание формы с помощью функции Автоформа (Autoform)


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

GardenCo

В этом упражнении вы создадите автоформу для ввода и просмотра данных о товарах. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap11\Autoform. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке.На панели объектов щелкните на пункте Формы (Forms).На панели инструментов окна база данных щелкните на кнопке Создать (New), чтобы отобразить диалоговое окно Новая форма (New Form), где представлены различные способы создания форм.


Щелкните на Автоформа: в столбец (Autoform Columnar), выделите таблицу Типы в списке внизу диалогового окна, а затем щелкните на кнопке ОК. Диалоговое окно закроется, и спустя несколько секунд на экране отобразится новая форма Типы.Щелкните на кнопке Сохранить (Save). В диалоговом окне Сохранение (Save As) примите заданное по умолчанию имя Типы и щелкните на кнопке ОК. Новая форма должна выглядеть, как показано на следующем рисунке.


Совет. При создании формы функция Автоформа (Autoform) применяет стиль фона, выбранный при последнем использовании мастера формы (или заданный по умолчанию стиль, если мастер пока еще не использовался). Если форма выглядит не так, как показано выше, переключитесь в режим конструктора, щелкните на команде Автоформа (Autoform) в меню Формат (Format) и выберите стиль The Garden Company из списка. Хотя форма выглядит неплохо, переключитесь в режим конструктора, чтобы внести некоторые улучшения.Удалите слово "Типа" из надписи "Название типа".Так как код типа КодТипа присваивается автоматически и не подлежит изменению, следует запретить доступ к этому полю. Щелкните на нем и, если нужно, нажмите на клавишу (F4), чтобы отобразить диалоговое окно Свойства (Properties).На вкладке Данные (Data) для свойства Доступ (Enabled) установите значение Нет (No).Переключитесь в режим формы и просмотрите несколько записей. Попытайтесь изменить содержимое поля Код типа, чтобы убедиться, что это невозможно. Уберите селектор формы и полосы прокрутки. Для этого вернитесь в режим конструктора, щелкните на селекторе формы и нажмите на клавишу (F4), чтобы отобразить диалоговое окно Свойства (Properties). На вкладке Макет (Format) для свойства Полосы прокрутки (Scroll Bars) установите значение Отсутствуют (Neither), а для свойства Области выделения (Record Selector) - Нет (No).Сохраните и закройте форму Типы.Закройте базу данных.



Создание главной и подчиненной форм с помощью мастера


Если при создании формы известно, что она должна содержать подчиненную, можно поручить эту работу мастеру, выполнив следующие шаги.

На панели объектов щелкните на пункте Формы (Forms), а затем щелкните на кнопке Создать (New) на панели инструментов окна базы данныхЩелкните на Мастер формы (Form Wizard), выберите базовую таблицу и щелкните на кнопке ОК.Убедитесь, что в поле Таблицы и запросы (Tables/Queries) указана выбранная вами таблица, и щелкните на кнопке >>, чтобы включить все поля в новую форму.Откройте список поля Таблицы и запросы (Tables/Queries) и выделите базовую таблицу для подчиненной формы.Щелкните дважды на нужных полях, чтобы добавить их в список выбранных полей, а затем щелкните на кнопке Далее (Next).Примите заданный по умолчанию вариант Таблица (Datasheet) и щелкните на кнопке Далее (Next).Щелкните на кнопке Готово (Finish), чтобы создать главную и подчиненную формы.

Теперь можно доработать форму в соответствии с вашими нуждами так же, как это делалось в предыдущем упражнении.

on_load_lecture()

Перейти к вопросам »

  Если Вы заметили ошибку - сообщите нам.  

Страницы:

« |

1

|

2

|

вопросы | »

|

учебники

|

для печати и PDA

Курсы | Учебные программы | Учебники | Новости | Форум | Помощь



Телефон: +7 (495) 253-9312, 253-9313, факс: +7 (495) 253-9310, email: info@intuit.ru

© 2003-2007, INTUIT.ru::Интернет-Университет Информационных Технологий - дистанционное образование



Фильтрация записей в таблице


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

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

Совет. Фильтрация записей осуществляется с помощью команды Фильтр (Filter) в меню Записи (Records), кнопок на панели инструментов и команд в контекстном меню. Доступ к этим командам зависит от конкретной ситуации.GardenCo

В этом упражнении вы воспользуетесь несколькими способами фильтрации записей. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\FilterDS. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. Откройте таблицу Клиенты в режиме таблицы. Щелкните на значении «Бойсе» в поле Город, а затем щелкните на кнопке Фильтр по выделенному (Filter By Selection). В таблице из 109 записей останутся 2, поскольку в Бойсе живут только два клиента. Важно. При фильтрации таблицы, записи, не отвечающие условиям отбора, не удаляются, а просто перестают отображаться. Щелкните на кнопке Удалить фильтр (Remove Filter), чтобы снова отобразить все записи таблицы. Отобразите всех клиентов, имеющих почтовый индекс, начинающийся с символов «V3F». Для этого найдите в таблице запись с таким индексом, выделите символы «V3F», а затем щелкните на кнопке Фильтр по выделенному (Filter By Selection). В таблице останутся только две записи, имеющие почтовые индексы, начинающиеся с «V3F». Щелкните на кнопке Удалить фильтр (Remove Filter). Если таблица слишком велика, чтобы искать в ней запись, содержащую «V3F» в почтовом индексе, можно воспользоваться контекстным меню. Щелкните правой кнопкой мыши на любом почтовом индексе, в контекстном меню щелкните в поле Фильтр для (Filter For), введите V3F* и нажмите на клавишу (Enter). Звездочка (*) является заменителем символов и означает, что нужно найти все вхождения почтового индекса, начинающие с «V3F». Чтобы отобразить клиентов, живущих вне Соединенных Штатов, удалите текущий фильтр, щелкните правой кнопкой мыши в поле Страна, которое содержит значение «США», и щелкните на команде Исключить выделенное (Filter Excluding Selection) в контекстном меню. В таблице отобразятся клиенты из других стран (в данном случае из Канады).




Заменитель символов

Если точное значение критерия отбора неизвестно, можно воспользоваться заменителями символов (wildcard characters). Наиболее распространенные из них представлены в следующей таблице:

СимволНазначениеПример
*Заменяет любое число символовLname = Co* возвращает значения типа Colman и Conroy
?Заменяет один символFname = eri? возвращает значения типа Ericи Erik
#Заменяет одну цифруID = 1## возвращает все значения от 100 до 199
Чтобы поэкспериментировать с еще одним способом фильтрации, удалите фильтр, сохраните и закройте таблицу Клиенты, а затем откройте таблицу Заказы в режиме таблицы. Чтобы отобразить все заказы, принятые Майклом Эмони 23 января, в поле Сотрудники щелкните правой кнопкой мыши на Эмони, Майкл и щелкните на команде Фильтр по выделенному (Filter By Selection) в контекстном меню. Щелкните правой кнопкой мыши в поле ДатаРазмещения, содержащем значение 1/23/01, и снова щелкните на команде Фильтр по выделенному (Filter By Selection) в контекстном меню. В таблице останутся только заказы, сделанные Майклом 23 января. Можно усложнить фильтр, добавив условие отбора по другому полю, или отсортировать результаты фильтрации. Для этого щелкните в поле сортировки, а затем щелкните на одной из кнопок Сортировка (Sort). Совет. Отобрав и упорядочив нужную информацию, можно отобразить результаты в виде формы или запроса. Щелкните на кнопке Новый объект (New Object) на панели инструментов и следуйте указаниям.Удалите фильтры, щелкнув на кнопке Удалить фильтр (Remove Filter). Сохраните и закройте таблицу Заказы. Закройте базу данных. Совет. Команды фильтрации позволяют фильтровать записи таблицы и при работе с формой. Особенно полезной может оказаться команда Фильтр для (Filter For), поскольку не требует отображения выделяемого значения в поле формы.

Использование функции Изменить фильтр (Filter By Form)


С помощью функции Изменить фильтр (Filter By Form) можно легко и быстро создать сложный фильтр, основанный на содержимом полей таблицы. Если открыть таблицу, а затем щелкнуть на кнопке Изменить фильтр (Filter By Form) вместо записей таблицы отобразится пустая строка, ячейки которой представляют собой поля со списками, содержащими все значения, встречающиеся в данном столбце таблицы.


Выбрав элемент из списка, можно щелкнуть на кнопке Применить фильтр (Apply Filter), чтобы отобразить только те записи, которые содержат выбранное значение.

Если таблица содержит десятки полей, использование функции Изменить фильтр (Filter By Form) усложняется, поскольку приходится прокручивать таблицу по горизонтали. В этом случае лучше воспользоваться кнопкой Изменить фильтр (Filter By Form) в режиме формы. Вместо исходной формы отобразится пустая форма, предназначенная для создания фильтра. Если щелкнуть в любом поле, а затем щелкнуть на стрелке, появится список всех значений поля, как показано ниже.


Выбрав значение и щелкнув на кнопке Применить фильтр (Apply Filter), щелкните на кнопке Следующая запись (Next), чтобы отобразить первую из отобранных записей. Воспользуйтесь кнопками перехода, чтобы просмотреть остальные записи.

Совет. Функция Изменить фильтр (Filter By Form) применима как в режиме таблицы, так и формы. В тех случаях, когда проще задать фильтр в форме, а просматривать результаты удобнее в таблице, можно быстро создать форму, воспользовавшись функцией Автоформа (Autoform). Затем, определив фильтр в форме, можно переключиться в режим таблицы для просмотра результатов.GardenCo

В этом упражнении вы воспользуетесь функцией Изменить фильтр (Filter By Form), что найти клиента, фамилию которого забыли, но уверены, что он живет либо в Калифорнии, либо в Вашингтоне, а фамилия начинается с буквы «С». В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\FilterForm. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на пункте Формы (Forms), а затем щелкните дважды на форме Клиенты, чтобы открыть ее в режиме формы. Щелкните на кнопке Изменить фильтр (Filter By Form) на панели инструментов. Вместо формы Клиенты, в которой отображалась запись таблицы, появится аналогичная форма с пустыми полями и вкладками Найти (Look for) и Или (Or), указанными внизу. Щелкните во втором поле Имя, введите с* и нажмите на клавишу (Enter) (указав тем самым, что нужно отобразить всех клиентов, фамилии которых начинаются с «С»). Access преобразует введенное значение в выражение: Like "с*" . Щелкните в поле Штат и выделите в списке Калифорния. Щелкните на кнопке Применить фильтр (Apply Filter), чтобы отобразить клиентов из Калифорнии, фамилии которых начинаются с буквы «С». Окно фильтра заменится формой Клиенты. На панели перехода внизу формы указано, что найдено 3 записи. Щелкните на кнопке Изменить фильтр (Filter By Form), чтобы вернуться к фильтру. Поля формы все еще содержат заданные значения. При создании фильтра условия отбора сохраняются до тех пор, пока их не заменят другими. Чтобы добавить в условия отбора клиентов из другого штата, щелкните на вкладке Или (Or). Эта вкладка содержит те же пустые поля, что и вкладка Найти (Look for). Совет. При переходе на вкладку Или (Or) появляется вторая вкладка Или (Or), позволяющая задать третье условие. В поле Фамилия, введите с*, в поле Штат выделите из списка или введите значение Вашингтон, а затем щелкните на кнопке Применить фильтр (Apply Filter). Прокрутите форму, чтобы просмотреть шесть отфильтрованных записей. Закройте форму Клиенты, а затем закройте базу данных.



Отбор информации по нескольким критериям


Команды Фильтр по выделенному (Filter By Selection), Фильтр для (Filter For) и Изменить фильтр (Filter By Form) позволяют легко и быстро извлечь из базы данных нужную информацию, пока фильтры остаются относительно простыми. Но предположим, что требуется найти сведения о заказах, отправленных в западные штаты в определенный период времени одной из двух фирм, занимающихся доставкой. В подобных ситуациях, когда нужно создать сложный фильтр, содержащий несколько условий отбора или выражений, можно воспользоваться командой Расширенный фильтр (Advanced Filter/Sort).

Построение расширенного фильтра осуществляется с помощью бланка, представленного на следующем рисунке.


Бланк построения может использоваться только для одной таблицы.

Совет. Если простой запрос, созданный в окне фильтра, предполагается использовать в дальнейшем, сохраните его в виде запроса. Это можно сделать с помощью команды Сохранить как запрос (Save As Query) в меню Файл (File) или кнопки Сохранить как запрос (Save As Query) на панели инструментов. Можно также щелкнуть правой кнопкой мыши в окне фильтра, а затем щелкнуть на команде Сохранить как запрос (Save As Query) в контекстном меню. GardenCo

В этом упражнении вы воспользуетесь командой Расширенный фильтр (Advanced Filter/Sort), чтобы создать фильтр для отображения клиентов из двух штатов, а затем поэкспериментируете с бланком построения фильтра, чтобы оценить его возможности. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\AdvForm. Выполните следующие шаги:

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на Таблицы (Tables), а затем щелкните дважды на таблице Клиенты, чтобы открыть ее в режиме таблицы. В меню Записи (Records) укажите на команду Фильтр (Filter), а затем щелкните на Расширенный фильтр (Advanced Filter/Sort). Откроется окно фильтра со списком полей таблицы Клиенты в верхней части. Если бланк построения не пустой, щелкните на команде Очистить бланк (Clear Grid) в меню Правка (Edit). Щелкните дважды на поле Фамилия, чтобы скопировать его в ячейку Поле (Field) первого столбца бланка. Щелкните в ячейке Условие отбора (Criteria) в столбце Фамилия, введите c* и нажмите на клавишу (Enter). Введенное значение будет преобразовано к виду: Like "c*" . Прокрутите список полей таблицы Клиенты до конца и щелкните дважды на поле Штат, чтобы скопировать его в следующий свободный столбец бланка. Щелкните в ячейке Условие отбора (Criteria) в столбце Штат, введите Калифорния or Вашингтон и нажмите на клавишу (Enter). Введенное значение будет преобразовано к виду: "Калифорния" Or "Вашингтон", как показано ниже.






Условие отбора определяет теперь клиентов из штатов Калифорния и Вашингтон, фамилии которых начинаются с буквы «С». В меню Фильтр (Filter) щелкните на команде Применить фильтр (Apply Filter/Sort), чтобы отобразить все записи, удовлетворяющие заданным условиям.



Совет. Уменьшив размеры окон, можно одновременно видеть фильтр и таблицу. В меню Записи (Records) укажите на команду Фильтр (Filter), а затем щелкните на Расширенный фильтр (Advanced Filter/Sort), чтобы вернуться в окно фильтра. Щелкните в ячейке Или (Or) в столбце Фамилия, введите в* и нажмите на клавишу (Enter). Бланк построения будет выглядеть следующим образом.



В меню Фильтр (Filter) щелкните на команде Применить фильтр (Apply Filter/Sort). При построении фильтра условия, заданные в одной строке, объединяются оператором И (And), а условия, заданные в разных строках - оператором Или (Or). Поэтому результаты отбора включают клиентов, проживающих в Калифорнии или Вашингтоне, фамилии которых начинаются с буквы «С», и клиентов с фамилиями, начинающимися с буквы «В», независимо от их местожительства. Вернитесь в окно фильтра, введите Калифорния or Вашингтон в ячейку Или (Or) в столбце Штат и нажмите на клавишу (Enter). Снова примените фильтр, чтобы отобразить клиентов только из штатов Калифорния и Вашингтон. Закройте таблицу Клиенты без сохранения изменений, а затем закройте базу данных.


Сортировка данных


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

ФамилияИмя
КембеллДевид
КембеллМишель
КенедиКевин
КерниНил
КимШейн

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

GardenCo

В этом упражнении вы воспользуетесь различными способами сортировки данных в таблице и форме. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\Sort. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. Откройте таблицу Клиенты в режиме таблицы. Чтобы отсортировать таблицу по полю Штат, щелкните в любом месте столбца Штат, а затем щелкните на кнопке Сортировка по возрастанию (Sort Ascending). Записи будут упорядочены по регионам. Совет. Можно также воспользоваться командами Сортировка по возрастанию (Sort Ascending) и Сортировка по убыванию (Sort Descending) в меню Записи (Records) или щелкнуть правой кнопкой мыши на столбце, а затем щелкнуть на нужной команде в контекстном меню.Чтобы изменить порядок сортировки на обратный (при условии, что курсор все еще находится в столбце Штат), щелкните на кнопке Сортировка по убыванию (Sort Descending). Записи для штата Орегон находятся теперь в начале списка. В обоих случаях сортировка осуществлялась по алфавиту, но данные в поле Город располагаются беспорядочно. Очевидно, что список выиграет, если упорядочить города внутри регионов.

Принципы сортировки в Access

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

Исходный списокОтсортированный как текстОтсортированный как числа
111
1234112
23123
312344
1125
222211
122312
4322
2423
551234




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

Совет. При сортировке записей по нескольким полям сортировка осуществляется последовательно, слева направо. Поэтому поля сортировки должны быть смежными и располагаться в нужной последовательности. Чтобы разместить столбец Штат слева от поля Город, щелкните на заголовке столбца и перетащите его влево, пока между полями Адрес и Город не появится темная линия. Так как столбец Штат уже выделен, нажмите на клавишу (Shift) и щелкните в заголовке столбца Город, чтобы распространить выделение на оба столбца. Щелкните на кнопке Сортировка по возрастанию (Sort Ascending), чтобы упорядочить записи по регионам и городам в порядке возрастания (города будут отсортированы внутри регионов). Совет. Просматривая записи в режиме формы, их можно отсортировать, но только по одному полю. Для этого щелкните в нужном поле, а затем щелкните на одной из кнопок Сортировка (Sort). Хотя порядок столбцов в таблице Клиенты не имеет особого значения, все же верните столбец Штат на прежнее место. Сохраните и закройте таблицу Клиенты. Закройте базу данных.

Выражения


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

Используя выражения, можно создавать сложные критерии, которые включают несколько условий отбора, объединенных логическими, арифметическими операторами и операторами сравнения.

Наиболее распространенными логическими операторами являются И (And), Или (Or) и Нет (Not). Если условия отбора объединены оператором И (And), будут отобраны записи, удовлетворяющие всем условиям. При использовании оператора Или (Or) искомые записи должны соответствовать хотя бы одному из заданных условий, а оператор Нет (Not) отберет только те записи, которые не отвечают ни одному из условий отбора.

Операторы сравнения включают следующие символы: > (меньше чем), < (больше чем) и = (равно). Кроме того, часто используются комбинации основных операторов: <= (меньше или равно), >= (больше или равно) и <> (не равно). Операторы сравнения иногда используются в сочетании с оператором Like, который проверяет значения полей на соответствие образцу.

Арифметические операторы (сложение (+), вычитание (-), умножение (*) и деление (/)) используются для действий над числами. Близкий к ним оператор & используется для сцепления (текстовый аналог сложения) двух текстовых строк.

on_load_lecture()

Перейти к вопросам »

  Если Вы заметили ошибку - сообщите нам.  

Страницы:

« |

1

|

2

|

3

|

4

|

вопросы | »

|

учебники

|

для печати и PDA

Курсы | Учебные программы | Учебники | Новости | Форум | Помощь



Телефон: +7 (495) 253-9312, 253-9313, факс: +7 (495) 253-9310, email: info@intuit.ru

© 2003-2007, INTUIT.ru::Интернет-Университет Информационных Технологий - дистанционное образование



Фильтры, сортировка и запросы


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

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

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

GardenCo

В этом упражнении вы создадите форму для ввода заказов, полученных по телефону. Форма базируется на запросе, содержащем сведения из таблиц Сведения о заказе и Товары. Запрос создает таблицу, в которой перечислены все товары с указанием их цен, количества, скидок и стоимости покупки. Поскольку стоимость не хранится в базе данных, ее нужно вычислить прямо в запросе. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\QueryDes. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на Запросы (Queries). Щелкните дважды на команде Создание запроса в режиме конструктора (Create query in Design View). Откроется окно запроса и диалоговое окно Добавление таблицы (Show Table), как показано на следующем рисунке.


увеличить изображение

Воспользуйтесь диалоговым окном Добавление таблицы (Show Table), чтобы указать таблицы и запросы, которые нужно включить в данный запрос. На активной вкладке Таблицы (Tables) щелкните дважды на таблицах Сведения о заказе и Товары, чтобы добавить их в окно запроса, и закройте диалоговое окно Добавление таблицы (Show Table).

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





Вверху каждого списка полей имеется звездочка, представляющая все поля таблицы. Ключевое поле отображается полужирным шрифтом. Линия, соединяющая поля КодТовара в обеих таблицах, указывает, что эти поля связаны. Совет. Чтобы добавить в запрос дополнительные таблицы, откройте диалоговое окно Добавление таблицы (Show Table). Для этого щелкните правой кнопкой мыши в верхней части окна запроса и воспользуйтесь командой Добавить таблицу (Show Table) в контекстном меню или щелкните на кнопке Отобразить таблицу (Show Table) на панели инструментов.

Нижняя часть окна запроса занята бланком, предназначенным для построения условий отбора. Чтобы включить поля в запрос, нужно перетащить их из списков вверху окна в последовательные столбцы бланка запроса. Перетащите следующие поля:
Из таблицыПоле
Сведения о заказеКодЗаказа
ТоварыОписаниеТовара
Сведения о заказеЦена
Сведения о заказеКоличество
Сведения о заказеСкидка


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

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


увеличить изображение

Лекция: Создание запроса


Щелкните на кнопке Запуск (Run), чтобы выполнить запрос и отобразить результаты в виде таблицы.

Измените запрос таким образом, чтобы упорядочить результаты по полю КодЗаказа, и добавьте поле для вычисления стоимости товара, которая определяется умножением цены на количество за вычетом скидки.


Щелкните на кнопке Вид (View), чтобы вернуться в режим конструктора. Строка Сортировка (Sort) (третья на бланке) позволяет указать поле и принцип сортировки (по возрастанию или убыванию). Щелкните в ячейке Сортировка (Sort) в столбце КодЗаказа, щелкните на стрелке и щелкните на По возрастанию (Ascending). Поскольку ни одна из таблиц не содержит стоимость покупки, воспользуйтесь построителем выражений, чтобы вставить в бланк запроса выражение для расчета стоимости. Щелкните правой кнопкой мыши в ячейке Поле (Field) первого пустого столбца бланка (шестого), а затем щелкните на команде Построить (Build) в контекстном меню. Откроется диалоговое окно Построитель выражений (Expression Builder), приведенное на следующем рисунке.


Нужно построить следующее выражение: «Ccur([Сведения о заказе].[Цена]*[Количество]*(1-[Скидка])/100)*100» Функция Ccur , используемая в выражении, преобразует результаты вычислений в денежный формат. В первом столбце области элементов щелкните дважды на папке Функции (Functions), а затем щелкните на Встроенные функции (Build-In Functions). Во втором столбце отобразятся категории встроенных функций. Во втором столбце щелкните на категории Преобразование (Conversion), чтобы ограничить список функций в третьем столбце этой категорией. Щелкните дважды на функции Ccur в третьем столбце.

Построитель выражений

Выражения, используемые в фильтрах или запросах, обычно вводятся вручную или создаются с помощью функции Построитель выражений (Expression Builder). Чтобы открыть окно построителя, можно воспользоваться командой Построить (Build) в контекстном меню или щелкнуть на кнопке построителя : в конце поля, куда нужно ввести выражение.

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






Функция преобразования в денежный формат вставлена в поле выражения. Вместо заполнителя <<expr>>, заключенного в скобки, нужно вставить выражение, вычисляющее число, которое будет преобразовано в денежный формат.

Щелкните на <<expr>>, чтобы выделить его. Элемент, который вы вставите следующим, заменит выделенный фрагмент. Следующий элемент, который нужно вставить в выражение, - это поле Цена из таблицы Сведения о заказе. Щелкните дважды на элементе Таблицы (Tables), щелкните на Сведения о заказе, а затем щелкните дважды на Цена. Окно построителя выражений выглядит теперь, как показано ниже.



В результате последнего действия курсор оказался в конце выражения, после поля Цена, что и требуется. Теперь нужно умножить значение поля Цена на значение поля Количество. Щелкните на кнопке * (звездочка) в ряду операторов, расположенном под полем выражения. В выражении появится знак умножения и очередной заполнитель <<Выражение>> (<<expr>>). Щелкните на заполнителе <<Выражение>> (<<expr>>), чтобы выделить его, и вставьте поле Количество, щелкнув дважды на нем во втором столбце. Введенное выражение вычисляет стоимость товара, умножая цену на количество. Но, чтобы получить окончательный результат, необходимо вычесть скидки, предлагаемые на отдельные товары. Скидки указаны в поле Скидки и составляют 10-20% от стоимости товара. Проще рассчитать процент, который нужно заплатить (80-90% от стоимости), чем вычислять скидку, а затем вычитать ее из стоимости товара. Введите *(1-, щелкните дважды на поле Скидка и введите закрывающую скобку ). Окно построителя выражений теперь выглядит как на рисунке (расширьте окно, чтобы отобразить выражение полностью).


увеличить изображение

Хотя поле Скидка определено как процентное, в базе данных оно хранится в виде чисел от 0 до 1 (то есть, на экране отображается 10%, а в памяти хранится 0,1). Поэтому, если скидка составляет 10%, результат выражения (1- Скидка) равняется 0,9. Иначе говоря, при 10% скидке стоимость составит 0,9 от произведения цены на количество. Щелкните на кнопке ОК. Окно построителя выражений закроется, и выражение будет скопировано в ячейку бланка запроса. Нажмите на клавишу (Enter), чтобы завершить ввод выражения. Совет. Чтобы быстро подогнать ширину столбца под его содержимое, щелкните дважды на правой границе серой полосы вверху столбца. Access присвоил выражению имя Выражение1 (Expr1). Щелкните на нем дважды, чтобы выделить, и введите более содержательное имя Окончательная цена. Щелкните на кнопке Вид (View), чтобы отобразить результаты в режиме таблицы.


Создание запроса с помощью мастера


Процесс создания простого запроса с помощью мастера Создание запросов (Query Wizard) практически не отличается от создания формы с помощью мастера. Суть его заключается в выборе полей из существующих таблиц и запросов и добавлении их в новый запрос.

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

GardenCo

В этом упражнении вы воспользуетесь мастером, чтобы создать запрос, извлекающий сведения о заказах из таблиц Клиенты и Заказы. Записи этих таблиц связаны через поле КодКлиента. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\QueryWiz. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на Запросы (Queries), а затем щелкните дважды на команде Создание запроса с помощью мастера (Create query by using wizard). Откроется первая страница мастера Создание простых запросов (Simple Query Wizard). Совет. Можно также запустить мастер, щелкнув на команде Запросы (Queries) в меню Вставка (Insert) или щелкнув на кнопке Новый объект (New Object), а затем щелкнув дважды на Мастер простых запросов (Simple Query Wizard). В списке Таблицы и запросы (Tables/Queries) выделите Таблица: Заказы (Tables: Orders). Щелкните на кнопке >>, чтобы переместить все доступные поля в список Выбранные поля (Selected Fields). В списке Таблицы и запросы (Tables/Queries) выделите Таблица: Клиенты (Tables: Customers). Щелкните дважды на полях Адрес, Город, Штат, ПочтовыйИндекс и Страна, чтобы переместить их в список Выбранные поля (Selected Fields), а затем щелкните на кнопке Далее (Next). Совет. Если взаимосвязь между таблицами не установлена, будет предложено установить связь, а потом снова запустить мастер. Щелкните на кнопке Далее (Next), чтобы принять подробный вариант, заданный по умолчанию. Введите имя запроса Запрос на заказы, оставьте выделенным вариант Открыть запрос для просмотра данных (Open Query to view information) и щелкните на кнопке Готово (Finish).




Access выполнит запрос и отобразит результаты в виде таблицы. Прокрутите записи, чтобы убедиться, что отображаются сведения обо всех заказах.

Щелкните на кнопке Вид (View), чтобы переключиться в режим конструктора. Обратите внимание, что для всех полей выделены флажки в ячейках Вывод на экран (Show). Очистив флажок, можно отменить отображение поля, которое включено в запрос для сортировки или создания условия отбора, но не требуется при просмотре. Очистите флажки Вывод на экран (Show) для полей КодЗаказа, КодКлиента и КодСотрудника, а затем щелкните на кнопке Вид (View), чтобы переключиться в режим таблицы. Как видите, все три поля исключены из результатов запроса. Щелкните на кнопке Вид (View), чтобы вернуться в режим конструктора. Этот запрос извлекает все записи из таблицы Заказы. Можно ограничить просмотр заказами, сделанными в определенный период, преобразовав запрос в параметрический, который запрашивает диапазон дат при запуске. В столбце ДатаРазмещения щелкните в ячейке Условие отбора (Criteria) и введите Between [Введите начальную дату:] And [Введите конечную дату:]. Щелкните на кнопке Запуск (Run), чтобы выполнить запрос. Access отобразит следующее диалоговое окно.



Введите 1/1/01 и нажмите на клавишу (Enter). Во втором диалоговом окне Введите значение параметра (Enter Parameter Value) введите 1/31/01 и нажмите на клавишу (Enter). Появятся результаты запроса, содержащие только те заказы, которые были сделаны в указанный период. Закройте таблицу и щелкните на кнопке Да (Yes), чтобы сохранить запрос. Закройте базу данных.

Создание запроса в режиме конструктора


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

Запрос на выборку извлекает данные из одной или нескольких таблиц и представляет их в табличном виде. Этот тип запроса можно использовать для группировки записей, вычисления сумм, средних величин и других итоговых значений. Работая с результатами запроса, можно одновременно редактировать данные из нескольких таблиц.Параметрический запрос запрашивает ввод параметров (например, начальную и конечную дату). Этот тип запросов часто используется для получения отчетов за определенный период времени.Перекрестный запрос выполняет расчеты и группирует данные для анализа информации. Для элементов, расположенных в левом столбце и в верхней строке результатов запроса, могут вычисляться итоговые значения (сумма, количество или средняя величина). Ячейки на пересечении строк и столбцов также содержат вычисляемые значения.Запрос на действие вносит множественные изменения за одну операцию. Собственно, это запрос на выборку, который выполняет определенные действия над результатами отбора. Возможны четыре типа действий: обновление, удаление и добавление записей и создание таблицы. В двух последних случаях результаты запроса на выборку либо добавляются в существующую таблицу, либо для них создается новая таблица.Совет. Access включает также запросы SQL, но в этом курсе они не рассматриваются.



Вычисления в запросе


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

ФункцияНазначение
SumВычисляет сумму значений, содержащихся в поле
AvgВычисляет среднее арифметическое для всех значений пол
CountОпределяет число значений поля, не считая пустых (Null) значений
MinНаходит наименьшее значение поля
MaxНаходит наибольшее значение поля
StDevОпределяет среднеквадратичное отклонение от среднего зн
VarВычисляет дисперсию значений поля
GardenCo

В этом упражнении вы создадите запрос, который вычисляет число наименований товаров, имеющихся в продаже, среднюю цену товара и общую стоимость всех товаров. В качестве рабочей будет использоваться папка Office XP SBS\Access\Chap12\Aggrevate. Выполните следующие шаги.

Откройте базу данных GardenCo, расположенную в рабочей папке. На панели объектов щелкните на Запросы (Queries), а затем щелкните дважды на команде Создание запроса в режиме конструктора (Create query in Design View). Откроется окно запроса и диалоговое окно Добавление таблицы (Show Table). В диалоговом окне Добавление таблицы (Show Table) щелкните дважды на Товары, а затем щелкните на кнопке Закрыть (Close). Access добавит таблицу Товары в окно запроса и закроет диалоговое окно Добавление таблицы (Show Table). В списке полей таблицы Товары щелкните дважды на КодТовара, а затем - на Цена. Оба поля переместятся на бланк запроса. Щелкните на кнопке Групповые операции (Totals) на панели инструментов.

На бланке запроса появится дополнительная строка Групповая операция (Total), как показано ниже.


Щелкните в ячейке Групповая операция (Total) столбца КодТовара, щелкните на стрелке и выделите из списка Count. В ячейке Групповая операция (Total) появится слово Count. При выполнении запроса эта функция вычислит число записей, содержащих значение в поле КодТовара. В ячейке Групповая операция (Total) столбца Цена задайте значение Avg. Щелкните на кнопке Запуск (Run). Результаты запроса представляют собой одну запись, содержащую число товаров и их среднюю цену.






Щелкните на кнопке Вид (View), чтобы перейти в режим конструктора. В ячейке Поле (Field) третьего столбца введите = Цена *МинимальныйЗаказ и нажмите на клавишу (Enter).

Введенный текст будет преобразован в выражение, о чем свидетельствует префикс Выражение1: (Expr1:). Это выражение умножает цену товара на его количество.

В ячейке Групповая операция (Total) для третьего столбца задайте значение Sum, чтобы просуммировать значения, вычисленные с помощью заданного выражения. Выделите текст Выражение1 (Expr1) и введите Общая стоимость. Снова выполните запрос. Результаты показаны на следующем рисунке.



Закройте окно запроса, щелкнув на кнопке Нет (No) в ответ на предложение сохранить запрос. Закройте базу данных и выйдите из Access.