Работа с данными с помощью формы

Лабораторное занятие 3 . Создание сложных форм для работы с базой данных

Создание форм, содержащих элементы управления

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

работа с данными с помощью формы - student2.ru

Рисунок 19. Окно конструктора форм с элементами управления

Задание 12. Добавьте в форму Исполнители командные кнопку для выполнения операций удаления отображаемой в форме записи.

Для этого нужно выполнить следующие действия:

1. Откройте форму Исполнители в режиме конструктора.

2. В окне конструктора с помощью мыши раздвинуть область размещения формы на экране, переместив поле Примечание формы вниз так, чтобы освободить место для размещения кнопок (рис. 19).

3. Найдите на вкладке Конструктор в группе Элементы управления элемент Кнопка. Нарисуйте кнопку на форме с помощью мыши (рис.20).

4. В открывшемся диалоговом окне Создание кнопок выбрать категорию команды Обработка записей, предназначенную кнопке, и выбрать конкретное действие Удалить запись, которое будет выполняться при нажатии на кнопку. Нажать кнопку Далее.

5. В следующем диалоговом окне «оформите кнопку»: назначьте ей рисунок или введите текст (Удалить), который будет отображаться на кнопке, и щелкните кнопку Готово.

6. Проверьте работоспособность созданной кнопки. Для этого сначала занесите с помощью формы Исполнители новую запись в таблицу. Затем удалите новую запись с помощью созданной кнопки Удаление.

Задание 13. Создайте кнопку в форме Исполнители для поиска нужной записи, выполнив следующие операции:

1. Откройте форму Исполнители в режиме конструктора.

2. Нарисуйте еще одну кнопку

3. В окне Создание кнопок для категории Переходы по записям выберите действие Найти запись. Нажмите кнопку Далее.

4. В следующем окне мастера создания кнопок установите переключатель Текст. В поле слева от переключателя должна быть размещена та надпись, которую вы хотите видеть на кнопке управления (Поиск). Нажмите кнопки Далее и Готово. В форме Исполнители появиться появится новая кнопка Поиск.

Проверьте работоспособность созданной кнопки, организовав поиск любой записи в таблице Исполнители. Для этого следует:

1. Открыть форму Исполнители и перейти к первой записи.

2. Установить курсор в поле ввода ФИО.

3. Нажать кнопку Поиск.

4. В диалоговом окне Поиск и замена на вкладке Поиск записать образец для поиска (например: А.А.А). В раскрывающемся списке Просмотр выбрать позицию Все; в раскрывающемся список Совпадение установить - С начала поля.Нажмитекнопку Найти далее Для поиска следующей записи, удовлетворяющей заданным условиям, нужно щелкнуть кнопку Найти далее.

5. После завершения поиска закройте диалоговое окно поиска.

6. Повторите процедуру поиска, установив свой критерий поиска.

5.

работа с данными с помощью формы - student2.ru

Рисунок 20. Окно конструктора формы и окно мастера создания кнопок в процессе создания кнопки

Задание 14. Добавьте кнопки удаления и поиска в формы Услуги и Клиенты.

Работа с данными с помощью формы

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

Задание 15. Отсортируйте записи в списке исполнителей, упорядочив по полю ФИО в алфавитном порядке

Для этого нужно установить курсор в поле ФИО и выполнить команду Сортировка по возрастанию в группе Сортировка и фильтр на вкладке Главная.

Формы можно копировать. Для этого следует открыть окно базы данных, выделить нужную форму на левой боковой панели, щелкнув по форме правой кнопкой мыши и выполнить команду Копировать в контекстном меню. Затем щелкнуть правой кнопкой мыши по свободному месту левой боковой панели и выполнить команду Вставить (при выполнении команды вводится имя, под которым запишется в БД копия формы).

Задание 16. Скопируйте форму Клиенты, записав копию в БД под именем Данные о клиентах.

Вопросы для самоконтроля:

1. Как с помощью формы внести новую запись в таблицу?

2. Порядок поиска записи с помощью формы.

Создание сложных форм

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

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

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

Задание 17. Создайте с помощью Мастера форму для таблицы Заказы, выполнив следующие операции:

1. На вкладке Создание в группе Формы раскройте список Другие формы и выберите пункт Мастер форм.

2. В окне мастера Создание форм с помощью списка Таблицы и запросы выберите таблицы Заказы. Из списка Допустимые поля переместите в список Выбранные поля только следующие поля:НомерЗаказа, ДатаПриема, ДатаИсполнения. В последнем диалоговом окне установите переключатель «Изменить макет формы» (это приведет к переключению в режим Конструктора) и щелкните кнопку Готово.

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

4. Измените надписи перед полями «НомерЗаказа», «ДатаПриема» и «ДатаИсполнения», установив курсор в надпись двойным щелчком и введя с клавиатуры строки «Номер заказа», «Дата приема» и «Дата исполнения» соответственно. Такое оформление полей больше соответствует стандартному. Обратите внимание на то, что изменять следует текст только в левых прямоугольниках (надписях к полю). Значение самих полей изменять не надо!

5. Дата приема заказа обычно совпадает с текущей датой. Поэтому можно установить для этого поля значение по умолчанию – текущую дату и запретить ее «ручной» ввод с клавиатуры. Для этого:

- щелкните по полю ДатаПриема правой кнопкой мыши и в открывшемся контекстном меню выберите строку Свойства;

- в открывшемся диалоговом окне на вкладке Данные выберите строку Значение по умолчанию и щелчком по кнопке вызовите Построитель выражений;

- в окне программы-построителя раскройте щелчком по значку + папку Функции и двойным щелчком вложенную в нее папку Встроенные функции;

- в списке категорий встроенных функций выберите категорию Дата/время и в перечне функций этой категории – функцию Date, задающую текущую системную дату, установленную в компьютере;

- вставьте эту функцию щелчком по кнопке Вставить в выражение, вычисляющее значение по умолчанию;

- закройте построитель выражений, нажав кнопку ОК;

- в диалоговом окне свойств поля установите, что к полю нет доступа, и есть блокировка;

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

- Выберите на панели элементов управления элемент Поле со списком. Поместите поле на форме с помощью мыши.

- В открывшемся диалоговом окне установите переключатель Объект «поле со списком» будет использовать значения из таблицы или запроса и щелкните кнопку Далее.

- В следующем диалоговом окне установите в группе Показать переключатель Таблицы и выберите в открытом списке таблиц таблицу Услуги. Щелкните кнопку Далее.

- Выберите в очередном окне поля КодУслуги и Наименование таблицы Услуги для включения в форму и щелкните кнопку Далее.

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

- Установите переключатель Сохранить в поле и выберите из списка поле КодУслуги таблицы Заказы. Щелчком по кнопке Далее перейдите в следующее окно.

- Задайте имя Услуга и щелкните кнопку Готово.

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

- Среди элементов управления на вкладке Конструктор выберите элемент Поле и введите поле в форму.

- Щелкните по полю правой кнопкой мыши и в открывшемся контекстном меню выберите строку Свойства;

- В диалоговом окне команды на вкладке Данные выберите строку Данные и щелчком по кнопке вызовите Построитель выражений(рис. 21).

- Запишите формулу для определения стоимости (выбора из таблицы Услуги стоимости по коду услуги). Для этого нужно ввести выражение, содержащее, например, следующую функцию:

=DLookUp("[Стоимость]";"Услуги";"[Услуги]![КодУслуги] = " & [Forms]![Данные о клиентах]![Заказы]![КодУслуги])

(стоимость выбирается из поля Стоимость таблицы Услуги, причем выбирается стоимость той услуги, код которой будет зафиксирован при оформлении заказа клиентом).Для записи этой формулы использованы конструкции языка программирования Visual Basic for Applications (VBA). С этим языком можно познакомиться на специальных факультативных занятиях.

- Установите блокировку и отсутствие доступа в свойствах поля (стоимость нельзя менять при оформлении заказа).

- С левой стороны от поля в надпись вставьте слово Стоимость

8. Разместите на форме поле со списком для выбора исполнителя заказа, выполнив операции:

- Выберите на панели элементов управления элемент Поле со списком. Поместите поле на форме с помощью мыши.

- В открывшемся диалоговом окне установите переключатель Объект «поле со списком» будет использовать значения из таблицы или запроса и щелкните кнопку Далее.

- В следующем диалоговом окне установите в группе Показать переключатель Таблицы и выберите в открытом списке таблиц таблицу Исполнители. Щелкните кнопку Далее.

- Выберите в очередном окне поля НомерИсполнителя и ФИО таблицы Исполнители для включения в форму и щелкните кнопку Далее.

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

- Установите переключатель Сохранить в поле и выберите из списка поле НомерИсполнителя. Щелчком по кнопке Далее перейдите в следующее окно.

- Задайте имя Исполнитель и щелкните кнопку Готово.

работа с данными с помощью формы - student2.ru

Рисунок 21. Форма Заказы в режиме конструктора

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

- Выбрать элемент управления Флажок среди элементов управления и с помощью мыши разместить его на форме.

- Щелчком мыши установить текстовый курсор в поле надписи флажка и ввести надпись Оплачено.

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

- Закройте Конструктор и подтвердите сохранение внесенных в форму изменений.

- Откройте форму Заказы для просмотра (рис. 22).

работа с данными с помощью формы - student2.ru

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

Рисунок 22. Форма Заказы в режиме просмотра

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

Задание 18. Создать реляционную форму путем внедрения формы Заказы в форму Данные о клиентах. Для этого:

1. Выделите форму Данные о клиентах и откройте ее в режиме Конструктор;

2. Перетяните значок формы Заказы из левой боковой панели в нижнюю часть формы Данные о клиентах (копия формы Клиенты) на свободное место;

3. Отформатируйте элементы формы так, чтобы все они размещались на ней, и закройте конструктор.

Полученная форма должна иметь вид, показанный на рис. 23.

работа с данными с помощью формы - student2.ru

Рисунок 23. Форма Данные о клиентах. используемая для приема заказов

Задание 19. Введите с помощью формы Данные о клиентах информацию о заказчиках и «оформите» заказы для них, используя произвольные данные.

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

Вопросы для самоконтроля:

1. Как в форму вставить текущую дату или формулу?

2. Как вставить в форму раскрывающийся список и флажок?

3. Как создать реляционную форму из нескольких форм?

Наши рекомендации