Запросы на выборку в Access. Создание простого запроса на выборку Настройка условий на основе поля, которое не включается в вывод

Я хотел бы иметь возможность создать параметризованный запрос в MS Access 2003 и передать значения определенных элементов формы в этот запрос, а затем получить соответствующий набор результатов и выполнить с ними некоторые базовые вычисления. Я вкратце расскажу, как получить параметры запроса для заполнения элементами формы. Если мне нужно использовать VBA, это нормально.

5 ответов

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

Например, если вы хотите отфильтровать запрос по элементу управления LastName в MyForm, вы должны использовать это в качестве критерия:

LastName = Forms!MyForm!LastName

PARAMETERS [!MyForm!] Text (255); SELECT tblCustomers.* FROM tblCustomers WHERE tblCustomers.LastName=!!;

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

С другой стороны, если вы что-то делаете в коде, просто напишите SQL на лету и используйте буквальное значение элемента управления формы для создания предложения WHERE.

Вот фрагмент кода. Обновляет таблицу, используя параметр txtHospital:

Set db = CurrentDb Set qdf = db.QueryDefs("AddHospital") qdf.Parameters!txtHospital = Trim(Me.HospName) qdf.ReturnsRecords = False qdf.Execute dbFailOnError intResult = qdf.RecordsAffected

Вот пример SQL:

PARAMETERS txtHospital Text(255); INSERT INTO tblHospitals () VALUES ()

Есть три традиционных способа обойти эту проблему:

  1. Присвойте параметру какое-нибудь значение, чтобы пользователю было предложено ввести значение при выполнении запроса.
  2. Поле ссылки на форме (возможно скрытое)
  3. Создайте запрос на лету и не используйте параметры.

Я думаю, что это просто неправильно для меня, что вам придется вводить что-то вроде [?enter ISO code of the country] или ссылки на поля в вашей форме, такие как: !! .

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

Обычно я выбирал последний вариант, создавал запрос на лету и обновлял объект запроса по мере необходимости. Тем не менее, это распространено для атаки с использованием SQL-инъекций (случайно или специально, зная моих пользователей), и это просто неприлично.

"Ed. Start - for completion of the example dim qryStartDate as date dim qryEndDate as date qryStartDate = #2001-01-01# qryEndDate = #2010-01-01# "Ed. End "QUOTEING "stallyon": To pass parameters to a query in VBA " is really quite simple: "First we"ll set some variables: Dim qdf As Querydef Dim rst As Recordset "then we"ll open up the query: Set qdf = CurrentDB.QueryDefs(qryname) "Now we"ll assign values to the query using the parameters option: qdf.Parameters(0) = qryStartDate qdf.Parameters(1) = qryEndDate "Now we"ll convert the querydef to a recordset and run it Set rst = qdf.OpenRecordset "Run some code on the recordset "Close all objects rst.Close qdf.Close Set rst = Nothing Set qdf = Nothing

(Я не проверял это сам, только кое-что, что я собрал в своих путешествиях, потому что время от времени я хотел сделать это, но заканчивал тем, что использовал один из моих ранее упомянутых кладжей)

редактировать У меня наконец была причина использовать это. Вот фактический код.

"... Dim qdf As DAO.QueryDef Dim prmOne As DAO.Parameter Dim prmTwo As DAO.Parameter Dim rst as recordset "... "open up the query: Set qdf = db.QueryDefs("my_two_param_query") "params called param_one and "param_two "link your DAP.Parameters to the query Set prmOne = qdf.Parameters!param_one Set prmTwo = qdf.Parameters!param_two "set the values of the parameters prmOne = 1 prmTwo = 2 Set rst = qdf.OpenRecordset(dbOpenDynaset, _ dbSeeChanges) "... treat the recordset as normal "make sure you clean up after your self Set rst = Nothing Set prmOne = Nothing Set prmTwo = Nothing Set qdf = Nothing

DoCmd.SetParameter "frontMthOffset", -3 DoCmd.SetParameter "endMthOffset", -2 DoCmd.OpenQuery "QryShowDifference_ValuesChangedBetweenSELECTEDMonths"

где SQL запроса Access включает фактически в SQL. например

"select blah from mytable where dateoffset="

Все просто работает!

Давайте возьмем пример. параметризованный запрос выглядит так:

Select Tbl_Country.* From Tbl_Country WHERE id_Country = _ [?enter ISO code of the country]

и вы хотели бы иметь возможность получить это значение ([? enter... country] one) из формы, где у вас есть элементы управления и некоторые данные в нем. Ну... это может быть возможно, но требует некоторой нормализации кода.

Одним из решений было бы присвоение элементам управления формы определенной логики, такой как fid_Country для контроля, который будет держать id_Country значение. Затем ваш запрос может быть представлен в виде строки:

Qr = "Select Tbl_Country.* From Tbl_Country WHERE id_Country = "

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

Dim ctl as Control For each ctl in Me.controls If instr(qr,"[" & ctl.name & "]") > 0 Then qr = replace(qr,"[" & ctl.name & "]",ctl.value) End if Next i

При этом у вас будет полностью обновленный запрос, в котором параметры заменены реальными данными. В зависимости от типа fid_country (строка, GUID, дата и т.д.) Может потребоваться добавить дополнительные двойные кавычки или нет, чтобы получить окончательный запрос, например:

Qr = "Select Tbl_Country.* From Tbl_Country WHERE id_Country = ""GB"""

Это полностью совместимый с Access запрос, который вы можете использовать для открытия набора записей:

Set rsQuery = currentDb.openRecordset(qr)

Я думаю, что вы сделали здесь.

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

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

Открыть созданную в предыдущей лабораторной работе базу данных Деканат ТФ .

Создание межтабличных связей

В окне базы данных выбрать объект Таблицы . Щелкнуть по кнопке «Схема данных » на панели инструментов или выполнить команду «Сервис »  «Схема данных », используя командное меню. На экране появится окно «Схема данных » и окно «Добавление таблицы » (рис. 18).

Рис. 18. Диалоговое окно «Схема данных» и диалоговое окно «Добавление таблицы»

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

Перенести все таблицы в окно «Схема данных ». Изменить размер окон таблиц, чтобы был виден весь текст (рис. 19).

Чтобы создать связь между таблицами Студенты и Оценки в соответствии со Схемой данных надо подвести курсор мыши к полю Код студента в таблице Студенты и при нажатой клавише мыши перетащить это поле на поле Код студента в таблице Оценки , а затем отпустить кнопку мыши. Откроется окно «Изменение связей » (рис. 20).

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

Для создания связи щелкнуть по кнопке «Создать ».

Рис. 19. Внешний вид схемы данных базы данных «Деканат ТФ » до наложения связей

Рис. 20. Диалоговое окно задания параметров связи между полями таблиц

Аналогично в соответствии со Схемой данных создаются связи между остальными таблицами (рис. 21).

Рис. 21. Схема данных базы данных «Деканат ТФ »

При закрытии окна схемы данных ответить Да на вопрос о сохранении макета.

Созданные связи между таблицами базы данных могут быть изменены.

Для изменения связей нужно вызвать окно «Схема данных ». После этого установить курсор мыши на связь, которую нужно изменить и щелкнуть правой клавишей мыши. Появится контекстное меню (рис.22):

Рис. 22. Контекстное меню связи

Если выбрать команду «Удалить », то после подтверждения связь будет удалена. Если нужно изменить связь, выбрать команду «Изменить связь ». После этого в появившемся окне «Изменение связей » (в его верхней части) выбрать поля в таблицах, которые нужно связать и щелкнуть по кнопке «Создать ».

Запросы

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

Мы будем разрабатывать запросы в режиме Конструктора .

В Access можно создавать следующие типы запросов:

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

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

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

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

1. На удаление записи. Этот запрос удаляет группу записей из одной или нескольких таблиц.

2. На обновление записи. Вносит общие изменения в группу записей одной или нескольких таблиц. Позволяет изменять данные в таблицах.

3. На добавление записей. Добавляет группу записей из одной или нескольких таблиц в конец одной или нескольких таблиц.

4. На создание таблицы. Создает новую таблицу на основе всех или части данных из одной или нескольких таблиц.

    Запросы SQL . Создаются при помощи инструкций языка SQL , используемого в БД .

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

Теория Для создания запроса нужно открыть базу данных, перейти на вкладку Запросы и выбрать пункт «Создание запроса в режиме конструктора»

Пример В БД Деканат нужно найти адреса (номер общежития и комната) всех девочек 9701 группы. Вывести на экран фамилии в алфавитном порядке, номер общежития и комнату. Для создания запроса нужно открыть базу данных, перейти на вкладку Запросы и выбрать пункт «Создание запроса в режиме конструктора»

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

Пример Поля Фамилия, пол, группа находятся в таблице «Студенты» , поля номер общежития и комната находятся в таблице «Общежитие» . Поэтому в окне Добавление таблицы выберем эти таблицы и нажмем кнопку Добавить. Затем нажмем кнопку Закрыть. Результат:

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

Пример Результат: Автоматически заполнилась строка Имя таблицы и строка Вывод на экран. Птичка означает, что значение поля на экран выводится. Для вывода фамилий в алфавитном порядке выберем для поля Фамилия в строке Сортировка По возрастанию.

Пример Нам нужно выполнять отбор по полям Пол и Группа. Поэтому перетащим эти поля из таблиц в строку Поле. Эти поля на экран выводить не нужно, поэтому уберем птичку в строке Вывод на экран. Результат:

Пример Заполним строку Условие отбора. В этой строке для поля Пол укажем ж (см. таблицу), а для поля Группа укажем 9701. Результат: Эти поля имеют текстовый тип. Двойные кавычки добавились автоматически. Для выполнения запроса нажмите

Составление условий отбора Условия отбора - это ограничения, накладываемые на запрос для определения записей, с которыми он будет работать. В условиях отбора: значение поля типа дата/время заключается в знаки номера (#). Например, #05. 02. 2009# значение поля текстового типа заключается в прямые двойные кавычки ("). Для объединения двух полей текстового типа используется оператор &. имя поля заключается в квадратные скобки (). Условие отбора пишется в бланке запроса в строке «Условие отбора» в том поле по которому производится сравнение.

Проверка диапазона значений Для проверки на равенство, знак = можно не писать. Условие отбора Результат отбора = "Иванов" Отбор записей, содержащих фамилии, начиная с «Иванов» и до конца алфавита, в поле «Фамилия» Between Отбор записей, содержащих в поле «Дата» #02. 99# And даты в диапазоне от 2 февраля 1999 до 1 декабря 1999 #01. 12. 99# Not "США" Отбор записей содержащих в поле «Страна» любую страну за исключением США

Комбинирование условий отбора с помощью операторов and и or Если выражения вводятся в несколько ячеек Условие отбора, то они автоматически объединяются с помощью операторов And или Or. Если выражения находятся в разных ячейках, но в одной строке, то Microsoft Access использует оператор And

Комбинирование условий отбора с помощью операторов and и or Если же выражения находятся в разных строках бланка запроса, то Microsoft Access использует оператор Or.

Часть значения поля (Like) Оператор Like работает приблизительно так же, как шаблоны для поиска файлов. Выражение Результаты отбора Like "С*" Имена начинаются с буквы С Like "[А-Д]*" Имена находятся в диапазоне от А до Д Like "*тр*" Имена содержат сочетание букв «тр» Like "? ? " Имена состоят из четырех букв

Пустое значение поля Выражение Результаты отбора Is Null Отбор по полю, которое содержит значение Null, т. е. является пустым " " Отбор по полю, которое содержит строку нулевой длины

Запрос с параметром Параметр – информация для запроса, вводимая с клавиатуры. Используется в условии для отбора. Текст сообщения указывается в квадратных скобках. В конце обязательно «: » При выполнении такого запроса выводится окно: Результат.

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

Если вы хотите узнать больше о принципах работы запросов на примере базы данных Northwind, ознакомьтесь со статьей Общие сведения о запросах .

В этой статье

Общие сведения

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

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

Преимущества запросов

Запрос позволяет выполнять перечисленные ниже задачи.

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

    Примечание: Запрос только возвращает данные, но не сохраняет их. При сохранении запроса вы не сохраняете копию соответствующих данных.

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

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

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

Основные этапы создания запроса на выборку

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

    Выберите таблицы или запросы, которые хотите использовать в качестве источников данных.

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

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

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

Создание запроса на выборку с помощью мастера запросов

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

Подготовка

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

Дополнительную информацию о создании отношений между таблицами можно найти в статье Руководство по связям между таблицами .

Использование мастера запросов

    На вкладке Создание в группе Запросы нажмите кнопку Мастер запросов .

    В диалоговом окне Новый запрос выберите пункт Простой запрос и нажмите кнопку ОК .

    Теперь добавьте поля. Вы можете добавить до 255 полей из 32 таблиц или запросов.

    Для каждого поля выполните два указанных ниже действия.


  1. Если вы не добавили ни одного числового поля (поля, содержащего числовые данные), перейдите к действию 9. При добавлении числового поля вам потребуется выбрать, что именно вернет запрос: подробности или итоговые данные.

    Выполните одно из указанных ниже действий.


  2. В диалоговом окне Итоги укажите необходимые поля и типы итоговых данных. В списке будут доступны только числовые поля.

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

    1. Sum - запрос вернет сумму всех значений, указанных в поле.

      Avg - запрос вернет среднее значение поля.

      Min - запрос вернет минимальное значение, указанное в поле.

      Max - запрос вернет максимальное значение, указанное в поле.


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

    Нажмите ОК , чтобы закрыть диалоговое окно Итоги .

    Если вы не добавили в запрос ни одного поля даты и времени, перейдите к действию 9. Если вы добавили в запрос поля даты и времени, мастер запросов предложит вам выбрать способ группировки значений даты. Предположим, вы добавили в запрос числовое поле ("Цена") и поле даты и времени ("Время_транзакции"), а затем в диалоговом окне Итоги указали, что хотите отобразить среднее значение по числовому полю "Цена". Поскольку вы добавили поле даты и времени, вы можете подсчитать итоговые величины для каждого уникального значения даты и времени, например для каждого месяца, квартала или года.


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

    На последней странице мастера задайте название запроса, укажите, хотите ли вы открыть или изменить его, и нажмите кнопку Готово .

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

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

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

Создание запроса

Действие 1. Добавьте источники данных

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

Автоматическое соединение

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

Вы можете настроить соединения, добавленные приложением Access. Access выбирает тип создаваемого соединения на основе отношения, которое ему соответствует. Если Access создает соединение, но для него не определено отношение, Access добавляет внутреннее соединение.

Повторное использование одного источника данных

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

При добавлении источника данных во второй раз Access присвоит имени второго экземпляра окончание "_1". Например, при повторном добавлении таблицы "Сотрудники" ее второй экземпляр будет называться "Сотрудники_1".

Действие 2. Соедините связанные источники данных

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

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

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

Добавление соединения

Изменение соединения

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

Действие 3. Добавьте выводимые поля

Вы можете легко добавить поле из любого источника данных, добавленного в действии 1.

    Для этого перетащите поле из источника в верхней области окна конструктора запросов вниз в строку Поле бланка запроса (в нижней части окна конструктора).

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

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

Использование выражения в качестве выводимого поля

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

    В пустом столбце таблицы запроса щелкните строку Поле правой кнопкой мыши и выберите в контекстном меню пункт Масштаб .

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

    Примечание: С помощью выражений можно выполнять самые разные задачи. Их подробное рассмотрение выходит за рамки этой статьи. Дополнительные сведения о создании выражений см. в статье Создание выражений .

Действие 4. Укажите условия

Это необязательно.

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

Определение условий для выводимого поля

    В таблице конструктора запросов в строке Условие отбора поля, значения в котором вы хотите отфильтровать, введите выражение, которому должны удовлетворять значения в поле для включения в результат. Например, чтобы включить в запрос только записи, в которых в поле "Город" указано "Рязань", введите Рязань в строке Условие отбора под этим полем.

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

    Укажите альтернативные условия в строке или под строкой Условие отбора .

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

Условия для нескольких полей

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

Настройка условий на основе поля, которое не включается в вывод

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

    Добавьте поле в таблицу запроса.

    Снимите для него флажок в строке Показывать .

    Задайте условия, как для выводимого поля.

Действие 5. Рассчитайте итоговые значения

Этот этап является необязательным.

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

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

    Когда запрос открыт в конструкторе, на вкладке "Конструктор" в группе "Показать или скрыть" нажмите кнопку Итоги .

    Access отобразит строку Итого на бланке запроса.

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

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

Чтобы увидеть результаты запроса, на вкладке "Конструктор" нажмите кнопку Выполнить . Access отобразит результаты запроса в режиме таблицы.

Чтобы вернуться в режим конструктора и внести в запрос изменения, щелкните Главная > Вид > Конструктор .

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

Создание запроса на выборку в веб-приложении Access

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


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

Открыть созданную в предыдущей лабораторной работе базу данных Деканат ТФ .

Создание межтабличных связей

В окне базы данных выбрать объект Таблицы . Щелкнуть по кнопке «Схема данных » на панели инструментов или выполнить команду «Сервис »  «Схема данных », используя командное меню. На экране появится окно «Схема данных » и окно «Добавление таблицы » (рис. 18).

Рис. 18. Диалоговое окно «Схема данных» и диалоговое окно «Добавление таблицы»

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

Перенести все таблицы в окно «Схема данных ». Изменить размер окон таблиц, чтобы был виден весь текст (рис. 19).

Чтобы создать связь между таблицами Студенты и Оценки в соответствии со Схемой данных надо подвести курсор мыши к полю Код студента в таблице Студенты и при нажатой клавише мыши перетащить это поле на поле Код студента в таблице Оценки , а затем отпустить кнопку мыши. Откроется окно «Изменение связей » (рис. 20).

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

Для создания связи щелкнуть по кнопке «Создать ».

Рис. 19. Внешний вид схемы данных базы данных «Деканат ТФ » до наложения связей

Рис. 20. Диалоговое окно задания параметров связи между полями таблиц

Аналогично в соответствии со Схемой данных создаются связи между остальными таблицами (рис. 21).

Рис. 21. Схема данных базы данных «Деканат ТФ »

При закрытии окна схемы данных ответить Да на вопрос о сохранении макета.

Созданные связи между таблицами базы данных могут быть изменены.

Для изменения связей нужно вызвать окно «Схема данных ». После этого установить курсор мыши на связь, которую нужно изменить и щелкнуть правой клавишей мыши. Появится контекстное меню (рис.22):

Рис. 22. Контекстное меню связи

Если выбрать команду «Удалить », то после подтверждения связь будет удалена. Если нужно изменить связь, выбрать команду «Изменить связь ». После этого в появившемся окне «Изменение связей » (в его верхней части) выбрать поля в таблицах, которые нужно связать и щелкнуть по кнопке «Создать ».

Запросы

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

Мы будем разрабатывать запросы в режиме Конструктора .

В Access можно создавать следующие типы запросов:

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

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

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

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

1. На удаление записи. Этот запрос удаляет группу записей из одной или нескольких таблиц.

2. На обновление записи. Вносит общие изменения в группу записей одной или нескольких таблиц. Позволяет изменять данные в таблицах.

3. На добавление записей. Добавляет группу записей из одной или нескольких таблиц в конец одной или нескольких таблиц.

4. На создание таблицы. Создает новую таблицу на основе всех или части данных из одной или нескольких таблиц.

    Запросы SQL . Создаются при помощи инструкций языка SQL , используемого в БД .