• 🔥 Бесплатный курс от Академии Кодебай: «Анализ защищенности веб-приложений»

    🛡 Научитесь находить и использовать уязвимости веб-приложений.
    🧠 Изучите SQLi, XSS, CSRF, IDOR и другие типовые атаки на практике.
    🧪 Погрузитесь в реальные лаборатории и взломайте свой первый сайт!
    🚀 Подходит новичкам — никаких сложных предварительных знаний не требуется.

    Доступ открыт прямо сейчас Записаться бесплатно

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

  • Автор темы Автор темы Баламут
  • Дата начала Дата начала
Б

Баламут

В общем столкнулся со странной проблемой.

В 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
 
Нашел. Оказывается ядро JET понимает только буржуйский формат даты.
Т.е. пишем

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

и все работает
 
запрос удобней переписать используя between. imho так лучше выглядит
 
В данном случае это не принципиально
 
Немного странно.. поидее наоборот должен работать во всех случах первый вариант .. а второй вариант только частность...
 
Сам удивляюсь, т.к. как я уже говорил, в предыдущих проектах таких казусов небыло. Но в справке по JETSQL ( файле JETSQL40.CHM, идет вместе с офисом) так и написано, что понимается ТОЛЬКО такой формат. Рыть надо
 
Мы в соцсетях:

Взломай свой первый сервер и прокачай скилл — Начни игру на HackerLab