Приветствую Вас Гость | RSS

Меню сайта

Реклама

Категории раздела
ADO [17]
ASCII и CSV [12]
Access [20]
Alias [24]
BDE [37]
BLOB поля [19]
Clipper [2]
DB2 [2]
DBASE и DBF [26]
Fox Pro [1]
Interbase [21]
MSSQL [0]
ODBC [10]
Oracle [0]
Paradox [0]
SQL [29]
Sybase [1]
База данных [0]
Закладки [2]
Записи [0]
Индексы [10]
Компоненты и Базы данных [0]
Модуль данных [3]
Отчеты [2]
Ошибки БД [17]
Поиск [16]
Поля [0]
Сортировка и Фильтр [6]
Таблицы [0]

Наш опрос
Оцените мой сайт
Всего ответов: 30

Статистика

Онлайн всего: 1
Гостей: 1
Пользователей: 0

Форма входа

Главная » Статьи » Базы данных » SQL

Параметризованные запросы

Как мне передать переменную в запрос?

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

 Select Test."FName", Test."Salary Of Employee"
From Test
Where Test."Salary of Employee" > :val
Примечание: Если вы просто пишете имя поля как "Salary of Employee", вы получите ошибку "Capability Not Supported". Это должно быть просто Test."Salary of Employee".

В нашем случае имя переменной "val", но это может быть любое другое (естественно). Затем вы переходите к свойству TQuery's params и устанавливаете параметр "val" в зависимости от требуемого типа. В нашем примере мы используем тип integer.

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


procedure TForm1.Button1Click(Sender: TObject);
begin
with Query1 do
begin
Close;
ParamByName('val').AsInteger := StrToInt(Edit1.Text);
Open;
end;
end;

Примечание: рекомендуем в качестве меры предосторожности разместить приведенный выше код в блоке try..except.

Если в своем запросе вы хотите использовать ключевое слово LIKE, то вы можете сделать это так:

Примечание: Следующий код использует таблицу пользователя, расположенную в каталоге \delphi\demos\data. При этом также возможно использование псевдонима DBDEMOS.

Код SQL для свойства TQuery.SQL:

 SELECT * FROM CUSTOMER
WHERE Company LIKE :CompanyName

Код Delphi:


procedure TForm1.Button1Click(Sender: TObject);
begin
with Query1 do
begin
Close;
ParamByName('CompanyName').AsString := Edit1.Text + '%';
Open;
end;
end;

Альтернативный способ передачи параметра (с последующим использованием ParamByName) - params[TheParameterNumber].

Вот демонстрация такого способа:


ParamByName('CompanyName').AsString := Edit1.Text + '%';

или, в качестве альтернативы:


Params[0].AsString := Edit1.Text + '%';

Хитрость шаблона - в конкатенирующем знаке процента в конце параметра.

Категория: SQL | Добавил: Skinner (29.07.2008)
Просмотров: 447 | Рейтинг: 0.0/0
  Delphi Lab   Главная   Регистрация   Вход  
Интересная Цитата

Поиск

Магазин


Copyright MyCorp © 2025 Хостинг от uCoz