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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.05.2009, 23:19
Corwin Corwin вне форума
Прохожий
 
Регистрация: 22.05.2009
Сообщения: 10
Репутация: 10
По умолчанию Поиск в интервале дат (ADO)

Необходимо реализовать поиск в интервале дат.
Есть 2 компонента DateTimePicker1 и DateTimePicker2, так же есть DBGrid.

Нужно чтобы всё это запускалось через обычную кнопку, и желательно что бы это было сделано на filtered

Заранее спасибо.
PS: бд ACCESS
Ответить с цитированием
  #2  
Старый 22.05.2009, 23:51
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,106
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну так и делай. Только там не на DBGrid, а на самом источнике данных делается.

Код:
procedure TForm1.ADOQuery1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
  If FMyFiltered
    Then
      Accept := (DataSet.FieldByName('Date1').AsDateTime > DateTimePicker1.Date) And
                (DataSet.FieldByName('Date1').AsDateTime < DateTimePicker2.Date)
    Else Accept := True;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  FMyFiltered := True;
end;

ЗЫ. Предпочитаю пользоваться этим событием - больше возможностей.
Ответить с цитированием
  #3  
Старый 22.05.2009, 23:54
Corwin Corwin вне форума
Прохожий
 
Регистрация: 22.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

Кхм...прошу прощения, но я нуб полный =\ выпускной курс, но увы, в колледже ничему не учили.
Цитата:
Только там не на DBGrid, а на самом источнике данных делается.
Не совсем понял...
Ответить с цитированием
  #4  
Старый 23.05.2009, 00:01
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Grid - это только средство отображения данных, потому запросы/фильтры надо использовать на источнике данных для отображения.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 23.05.2009, 00:07
Corwin Corwin вне форума
Прохожий
 
Регистрация: 22.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

Если чесно всё равно не понимаю как ЭТО работает свой предыдущий фильтр писал так :
Код:
procedure TFindeUnit.btn1Click(Sender: TObject);
begin
DataModule1.ADOTable1.Filtered:=false;
if Edit1.Text='' then exit;
DataModule1.ADOTable1.Filter:=Combobox1.Text + ' LIKE ' + #39 + Edit1.Text + '%' + #39;
DataModule1.ADOTable1.Filtered:=true;

end;

....Приношу извинения за нубство, но на самом деле вот только сейчас всё это осваиваю.
Ответить с цитированием
  #6  
Старый 23.05.2009, 00:22
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Вот так для даты можно попробовать:
Код:
procedure TFindeUnit.btn1Click(Sender: TObject);
begin
DataModule1.ADOTable1.Filtered:=false;
if Edit1.Text='' then exit;
DataModule1.ADOTable1.Filter:=Format('Date1 between DateValue(%s) and DateValue(%s)',[DateToStr(DateTimePicker1.Date),DateToStr(DateTimePicker2.Date)]);
DataModule1.ADOTable1.Filtered:=true;
end;
Но с датами там заморочки, может и не прокатить.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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