<< Click to Display Table of Contents >> Navigation: Создание отчетов > Источники данных, переменные и функции > Источники данных > Прочие источники > Источник данных СУБД > Запросы > Параметры |
При создании запроса есть возможность использовать объект Параметр (Parameter). Данный объект предназначен для передачи в запрос дополнительных условий для выборки данных. К примеру, если требуется, чтобы запрос использовал какое-либо значение вводимое пользователем при каждом выполнении запроса, то можно создать запрос с использованием параметров. Объект Параметр (Parameter) может быть использован только совместно с SQL источниками данных. Такие источники данных обычно имеют поле Текст запроса (Text Query). Для того, чтобы вставить параметр в запрос следует нажать кнопку Новый параметр (New Parameter):
После нажатия данной кнопки будет создан новый параметр, который будет отображен в группе Параметры (Parameters) на панели Колонки (Columns):
Каждый параметр имеет свойства, с помощью которых можно изменить его настройки. На рисунке снизу представлена свойства параметра:
Название |
Назначение |
Наименование |
Имя параметра. В случае именованного параметра |
Выражение |
Для каждого параметра можно указать значение, которое используется для заполнения параметра. Значение может быть выражением, const, выражение, ссылка на элемент словаря данных, к примеру переменная и т.д. К примеру, x+y или {variable} |
Размер |
Предоставляет возможность изменить размерность типа используемого в параметре. Следует помнить, что в базе данных каждый тип имеет свою размерность. Поэтому при использовании параметра в запросе, необходимо указывать корректную размерность типа. Для некоторых адаптеров баз данных размерность можно не указывать, но обычно если размерность не указана или указана неверно, то запросы с использованием таких параметров будут выполнены некорректно. |
Тип |
Значения данного свойства находятся в выпадающем списке, и представляет собой перечисление типов используемых в параметрах для конкретной базы данных. Стоит учитывать, что список типов отличается в зависимости от базы данных. |
Также параметр необходимо указать и в самом запросе. Ниже представлен пример схематичного расположения параметров в запросе:
Как правило, для указания параметра в запросе используется символ @. Символ @ используется с именованными параметрами, т.е. после символа @ следует имя параметра. Но в некоторых базах данных (к примеру в OleDB), символ @ может не восприниматься адаптером базы данных и запросы с параметрами работать не будут. В данном случае, можно использовать неименованные параметры. Для указания в запросе неименованных параметров используется символ ?. После символа ? не указывается имя параметра. В этом случае, важен порядок параметров в группе Параметры (Parameters). По мере указания символов ? в запросе, параметры будут браться последовательно из группы Параметры (Parameters) в направлении "сверху-вниз". Рассмотрим на примере. Допустим есть три параметра, которые указываются в запросе:
Поскольку в данном случае используются неименованные параметры (обозначенные символом ?), то при выполнении запроса параметры будут браться из группы Параметры (Parameters) последовательно "сверху-вниз". На рисунке снизу схематично представлено сопоставление параметров из группы Параметры (Parameters) к параметрам в запросе:
При этом, используемые параметры в данном примере, могут иметь имена, но при использовании символа ? они не играют роли. После того, как запрос с параметрами создан и выполнен, параметры также будут отображаться в Словаре (Dictionary), в созданном источнике данных, в группе Параметры (Parameters). На рисунке снизу представлен пример панели Словаря (Dictionary) и расположения в нем параметров:
Для того, чтобы отредактировать параметр отдельно от источника данных, следует выделить Параметр (Parameter) в словаре данных и дважды кликнуть по нему. Тогда будет отображено окно Редактирование параметра (Edit Parameter), в которым можно изменить настройки выделенного параметра. На рисунке снизу представлен пример окна Редактирование параметра (Edit Parameter):
В параметре как значение можно указать переменную. В этом случае, значения переменной будут значениями параметра при запросе. Использовать переменную в запросе как параметр можно двумя способами:
•Создать переменную в словаре данных. Открыть на редактирование запрос. Создать параметр в запросе. Указать переменную как значение этого параметра:
Прописать параметр в тексте запроса.
•При создании или редактировании переменной, установить флаг Разрешить использовать как SQL параметр (Allow using as SQL parameter):
Прописать эту переменную в тексте запроса, используя специальный символ "@" перед именем переменной.
Нажмите кнопку ОК в редакторе запросов Теперь переменная присутствует в источнике данных, и используется как параметр в запросе.