Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.06.2009, 10:33
WMaxaW WMaxaW вне форума
Прохожий
 
Регистрация: 24.05.2009
Сообщения: 10
Репутация: 10
По умолчанию как правильно записать функцию between с датами (даты берутся из DateTimePicker)

Есть два DateTimePicker и кнопка на каторую пасажен филтр

DataModule2.ADOTablepacient.Filter:='ДР between (DateTimePicker3.Date)and (DateTimePicker4.Date)';
фильтр не работает
подскажите как правильно записать функцию between с датами( даты берутся из DateTimePicker)
Ответить с цитированием
  #2  
Старый 02.06.2009, 11:49
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

мда... во-первых, теги. во-вторых:
Код:
DataModule2.ADOTablepacient.Filter:='ДР between  ('+DateToStr(DateTimePicker3.Date)+') and ('+DateToStr(DateTimePicker4.Date)+')';
про преобразование и сложение переменных почитай...
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj
Ответить с цитированием
  #3  
Старый 02.06.2009, 15:09
WMaxaW WMaxaW вне форума
Прохожий
 
Регистрация: 24.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

я так пробавала, но Delphi выдает ошибку
"аргументы имеют неверный тип выходят за пределы допустимого диапозона или вступают в конфликт с друг другом"
Ответить с цитированием
  #4  
Старый 02.06.2009, 15:41
Аватар для PhoeniX
PhoeniX PhoeniX вне форума
Always hardcore!
 
Регистрация: 04.03.2009
Адрес: СПб
Сообщения: 3,239
Версия Delphi: GCC/FPC/FASM
Репутация: 62149
По умолчанию

Хм... а, вспомнил. там надо как-то через (_|_) их преобразовать в SQL-ный формат дат... может, кто ответит, я хз как.
__________________
Оставайтесь хорошими людьми...
VK id2634397, ds [at] phoenix [dot] dj
Ответить с цитированием
  #5  
Старый 02.06.2009, 16:25
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Код:
var
myD1,myD2:string
begin
myD1:=DateToStr(DateTimePicker3.Date);
myD2:=DateToStr(DateTimePicker4.Date);
DataModule2.ADOTablepacient.Filter:='ДР>='+QuotedStr(myD1)+ ' and ДР<='+QuotedStr(myD2);
Я делал так, думаю, что и с between должно пролезть.
Если поле ДР тип DateTime, то должно все работать
Ответить с цитированием
  #6  
Старый 02.06.2009, 21:46
Аватар для Yurk@
Yurk@ Yurk@ вне форума
Специалист
 
Регистрация: 07.09.2007
Адрес: Украина, г. Днепропетровск
Сообщения: 892
Версия Delphi: 7 + ОгнеПтица
Репутация: выкл
По умолчанию

between используется в SQL, а для фильтра нужно просто сравнить
Код:
DataModule2.ADOTablepacient.Filter:='ДР >= '+DateToStr(D1)+' and ДР =< '+DateToStr(D2)+'
__________________
Поживу - увижу, Доживу - узнаю, Выживу - учту.
[P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз
Ответить с цитированием
  #7  
Старый 03.06.2009, 12:04
WMaxaW WMaxaW вне форума
Прохожий
 
Регистрация: 24.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

TOJluK и Yurk@ спасибо, я уже сама отказалась от between
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 08:36.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025