- •Информационная система управления торгово-закупочным предприятием на базе субд ms Access
- •Оглавление
- •1. Описание информационных объектов базы данных.
- •2.1. Создание таблицы «Кадры».
- •2.2. Конструирование других таблиц бд. Таблицы Клиенты и Поставщики .
- •Таблицы Заказы и Заказ-Товар.
- •3. Построение схемы данных.
- •4. Разработка форм базы данных.
- •4.1. Общие сведения о формах базы данных (Приложение).
- •4.2. Создание форм для ввода данных в таблицы "Кадры", "Клиенты", "Поставщики".
- •5. Создание формы «Склад».
- •1) Решение первой задачи.
- •2) Решение второй задачи.
- •3) Решение третьей задачи.
- •6. Создание сложной формы «Прием заказов».
- •6.1. Требования к форме "Прием заказов".
- •6.2. Создание запроса и построение главной формы «Прием заказов».
- •Выражение1:[Кадры]![Фамилия сотрудника]&" "&Left([Кадры]![Имя сотрудника];1)&"."& Left([Кадры]![Отчество сотрудника];1) & "."
- •6.3. Создание запроса и построение подчиненной формы.
- •6.4. Построение сложной формы "Прием заказов".
- •7. Создание пользовательского интерфейса.
- •Заключение
- •1. Свойство поля Подстановка таблицы бд.
- •2. Поле объекта ole
- •3. Общие сведения о формах базы данных
- •4. Проектирование запросов базы данных.
- •Литература
4. Проектирование запросов базы данных.
В СУБД Access проектирование запросов реализуется двумя способами:
запрос проектируется на основе бланка QBE (Query By Example). Пользователь при таком проектировании задает отдельные параметры запроса в окне проектирования с использованием подсказок и образцов;
запрос проектируется на основе структурированного языка запросов SQL (Structured Query Language). Формируя такой запрос, пользователь применяет инструкции и функции языка, выстраивая некоторое описание.
Типы запросов легко транслируются из одного вида в другой через меню "Вид", поэтому СУБД Access безразлично, каким образом строится запрос.
Основным видом запросов являются запросы на выборку, задаваемые по умолчанию. Другими видами могут быть: запрос на обновление или добавление (удаление).
С помощью запросов пользователь может выбирать из базы данных информацию, которая его интересует в данный момент времени. Результат запроса представляет собой виртуальную таблицу, которая называется Dynaset – динамический набор данных. В эту таблицу включают поля, выбранные из основных таблиц, записи которых удовлетворяют критериям отбора в запрос. Dynaset при каждом выполнении запроса строится заново на основе свежих табличных данных.
Бланк построения запроса называется бланком QBE. Каждый столбец бланка относится к одному полю, с которым будем работать в данном запросе. Он может быть просто полем одной из таблиц, вычисляемым полем или итоговым полем.
Строки бланка конструктора запросов.
Строка «поле» используется для выбора имен полей, которые должны присутствовать в наборе записей запроса, по которым надо провести сортировку или значение которых надо проверить. Имена полей, которые будут выводиться в запросах, можно изменить, также в этой строке можно создавать вычисляемые поля, используя построитель выражений.
Вторая строка конструктора запроса - «имя таблицы», в эту строку автоматически заносятся имена таблиц, из которых выбираются имена полей, по которым строится запрос.
Третья строка – сортировка данных. Access выводит записи в том порядке, в каком они записаны в таблицу. Если записи необходимо сортировать, то в столбце этого поля на строке «сортировка» выбирается одно из значений списка "по возрастанию/по убыванию".
Четвертая строка – вывод на экран. В этой строке устанавливается переключатель, определяющий – выводить на экран содержимое полей или нет. Часто в запрос требуется включить поля, по которым задают условия отбора, а содержимое этих полей на экран не выводится. В этом случае переключатель ставится в положение "выключен".
Описание работы со строками – «условие» и «или» определяется выбираемыми данными.
После заполнения бланка QBE для некоторых полей необходимо установить их свойства. В общем случае поля, выводимые в наборе записей запроса, наследуют свойства, заданные ранее соответствующим полям таблицы. Можно изменить значение этих свойств, а также задавать свойства для вычисляемых полей (для них желательно определять хотя бы одно свойство – «подпись поля»).
Окно диалога «свойства» можно вызвать клавишей F4, либо из контекстного меню. Можно задавать следующие свойства:
описание объекта. В это свойство заносится информация, которая выводится в строке состояния окна-запроса в режиме таблицы Dynaset или в формах, построенных по этому запросу, когда данное поле является текущим. Это свойство желательно заполнять;
формат поля – представление данных на экране компьютера;
маска ввода – определяет шаблон ввода данных в поле;
подпись поля - заголовок столбца в запросе.
В Access можно задавать вычисления над любыми полями таблицы и сделать вычисляемое значение новым полем в наборе записей. Для этого можно использовать встроенные функции, а также создавать поля с использованием арифметических операций над полями таблицы. Кроме того, можно создавать новые текстовые поля, как результат конкатенации текстовых полей и символьных констант.
Таблица. Операторы вычисления
-
Оператор
Действие
+
Сложение
-
Вычитание
*
Умножение;
/
Деление;
\
Округляет два арифметических выражения до целых значений и делит первое число на второе, результат округляется до целого;
^
Возводит первое арифметическое выражение в степень, заданную вторым выражением;
MOD
Округляет оба арифметических выражения до целых значений, делит первое число на второе и возвращает в качестве результата остаток;
&
Оператор конкатенации. Создает текстовую строку как результат присоединения второй строки или текстовой константы к концу первой. Если один из операторов является числом, Accessперед проведением конкатенации преобразует его в строку символов.
В запросах можно использовать следующие «Групповые операции».
Таблица. Групповые операции
-
Групповая операция
Действие
SUM
Вычисляет сумму всех полей заданного поля в каждой группе. Можно использовать только для числовых или денежных полей.
Avg
Вычисляет среднее арифметическое всех значений данного поля в каждой группе. Функция может использоваться только для числовых или денежных полей, и не включает в вычисления значение Null.
Min
Возвращает наименьшее значение, найденное в этом поле внутри каждой группы.
Max
Возвращает наибольшее значение внутри поля в каждой группе.
Count
Возвращает число записей, в которых значение данного поля отличны от Null
(с учетом значения Null, в строку «поле» вводится выражение:Count(*)).
StDev
Подсчитывают статистическое стандартное отклонение для всех значений данного поля в каждой группе (числовые или денежные поля). Если в группе меньше двух строк, то Accessвозвращает значениеNull.
Var
Подсчитывает статистическую дисперсию для всех значений данного поля по каждой группе. Эту функцию можно применять только к числовым или денежным полям. Если в группе меньше двух строк, то Accessвозвращает значениеNull.
First
Last
Возвращает первое значение поля в группе или последнее значение поля в группе.
*****************************************************************************