|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
sql запрос с датой
Делаю выборку из БД (MS Access) по дате.
Никак не получается составить правильный запрос к БД. Пробовал так: Код:
ADOQuery1.Close; ADOQuery1.SQL.Clear; s:='select * from material '; s:=s+'where [Дата поступления] > #'+DateToStr(FromDate1.Date-1)+ '# and [Дата поступления]< #'+DateToStr(ToDate1.Date)+'#'; ADOQuery1.SQL.Add(s); ADOQuery1.Open; Вместо # использовал " - результат такой же. И так пробовал: Код:
ADOQuery1.SQL.Text:= 'select * from material WHERE (data>= :date1) and (data<= :date2)'; ADOQuery1.Parameters.ParamByName('date1').Value:= FromDate1.DateTime; ADOQuery1.Parameters.ParamByName('date2').Value:= ToDate1.DateTime; |
#2
|
|||
|
|||
1. Дата кодируется с помощью одиночных кавычек.
2. Лучше для параметров типа дата использовать параметризованный запрос. 3. Тип параметров задай принулительно (входной типа TDateTime) |
#3
|
|||
|
|||
Спасибо, с параметрами всё работает отлично.
Кстати с одиночными кавычками тоже выдавало ошибку "Дата содержит синтаксическую ошибку в выражении запроса..." Последний раз редактировалось Eugene86, 26.09.2009 в 16:31. |
#4
|
||||
|
||||
попробуй так:
Код:
ADOQuery1.Close; ADOQuery1.SQL.Text:='select * from materialcopy WHERE (data>= :date1) and (data<= :date2)'; ADOQuery1.ParamByName('date1').AsDateTime:= FromDate1.DateTime; ADOQuery1.ParamByName('date2').AsDateTime:= ToDate1.DateTime; ADOQuery1.Open; Поживу - увижу, Доживу - узнаю, Выживу - учту. [P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз
|