Поиск в интервале дат

Баламут

Well-known member
27.07.2005
76
0
#1
В общем столкнулся со странной проблемой.

В AdoQuery строка SQL выглядит так:
[sql]SELECT * FROM Таблица where Дата >= :D 1 and Дата <= :D 2[/sql]

В коде пишу:

Adoquery1.Parameters[0].Value := DateTimePicker1.Date;
Adoquery1.Parameters[1].Value := DateTimePicker2.Date;
Adoquery1.ExecSQL;

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

База локальная, Access
 

Баламут

Well-known member
27.07.2005
76
0
#2
Нашел. Оказывается ядро JET понимает только буржуйский формат даты.
Т.е. пишем

Adoquery1.Parameters[0].Value := FormatDateTime('mm/dd/yyyy', DateTimePicker1.Date);

и все работает
 
?

????

#3
запрос удобней переписать используя between. imho так лучше выглядит
 
B

Barmutik

#5
Немного странно.. поидее наоборот должен работать во всех случах первый вариант .. а второй вариант только частность...
 

Баламут

Well-known member
27.07.2005
76
0
#6
Сам удивляюсь, т.к. как я уже говорил, в предыдущих проектах таких казусов небыло. Но в справке по JETSQL ( файле JETSQL40.CHM, идет вместе с офисом) так и написано, что понимается ТОЛЬКО такой формат. Рыть надо