Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.09.15;
Скачать: CL | DM;

Вниз

Dynamic SQL   Найти похожие ветки 

 
reticon   (2003-08-26 11:04) [0]

Совсем задолбался с параметрическими запросами...
Пишу, допустим, такой код:

var
name: string;
...
name:=DBLookupComboBox1.Text;
with Query1 do
begin
Close;
SQL.Clear;
SQL.Add("SELECT * FROM OUT WHERE NAME = :name");
SQL.Open;
end;


Здесь все работает. (Тип поля NAME - строковый и переменная name тоже строка).
Идем дальше. Еще пишу такой код:

var
date1, date2: string;
...
date1:=DateToStr(DateTimePicker1.Date);
date2:=DateToStr(DateTimePicker2.Date);
with Query1 do
begin
Close;
SQL.Clear;
SQL.Add("SELECT * FROM OUT WHERE DATE BETWEEN :date1 AND :date2");
//SQL.Add("SELECT * FROM OUT WHERE DATA BETWEEN "+DateToStr(date1)+" AND "+DateToStr(date2)+"");
SQL.Open;
end;


При выполнении этого запроса выдает ошибку "Field date1: Not Found"
(при условии, что тип поля DATE и переменной date1 - строковый).
Если же в таблице изменить тип поля DATE на тип Date и тип переменной date1 изменить на TDateTime,
то ошибка выдается, например, в таком виде: "Token not found. Token: 24.08". Вообще хочу отобрать записи между двумя датами.

Кто знает, где здесь грабли?


 
Reindeer Moss Eater   (2003-08-26 11:16) [1]

SELECT * FROM OUT WHERE DATE BETWEEN :date1 AND :date2"

Откуда такая любовь к зарезервированным словам?


 
NickBat   (2003-08-26 11:17) [2]

Что-то не видно где ты параметры подставляешь в запрос?


 
asp   (2003-08-26 11:17) [3]

На Fox"е раньше работал? ;)
...
with Query1 do
begin
Close;
SQL.Clear;
SQL.Add("SELECT * FROM OUT WHERE DATE BETWEEN :date1 AND :date2");
//SQL.Add("SELECT * FROM OUT WHERE DATA BETWEEN "+DateToStr(date1)+" AND "+DateToStr(date2)+"");
end;
Query1.ParamByName("date1").DataType:= ftDate;
Query1.ParamByName("date1").AsDate:= DateTimePicker1.Date;
Query1.ParamByName("date2").DataType:= ftDate;
Query1.ParamByName("date2").AsDate:= DateTimePicker1.Date;
Query1.Open;
...


 
Sergey13   (2003-08-26 11:23) [4]

Интересно а какие строки находятся между "мама" и "папа"? Зачем для даты строковый формат? Напиши код для варианта с форматом DATE.


 
Соловьев   (2003-08-26 11:49) [5]


> SQL.Add("SELECT * FROM OUT WHERE DATE BETWEEN :date1 AND
> :date2");

...
SQL.Add("SELECT t1.* FROM OUT t1 WHERE t1."DATE" BETWEEN :date1 AND
:date2");
...
ParamByName("date1").AsDateTime := date1;
ParamByName("date2").AsDateTime := date2;
Open;
...


 
reticon   (2003-08-26 14:43) [6]

Всем спасибо...все нормально работает.
Жара просто в Сочи...



Страницы: 1 вся ветка

Текущий архив: 2003.09.15;
Скачать: CL | DM;

Наверх




Память: 0.45 MB
Время: 0.01 c
3-48433
dot
2003-08-25 10:15
2003.09.15
Как сделать фильтр по нескольким полям?


3-48401
Anna
2003-08-26 11:36
2003.09.15
Фильтры и диапазоны


14-48685
mister-AK
2003-08-28 21:02
2003.09.15
Чем проявить окна? Скрылось приложение под WinXP


4-48821
Still Swamp
2003-07-16 17:45
2003.09.15
Позиция клиентского RECT для окна


6-48666
Виль
2003-07-13 14:53
2003.09.15
FTP- сервер на ПК ответ на модемное диалаповское соединение.





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский