Форум по 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,015
Версия 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,721
Репутация: 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,721
Репутация: 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;
Но с датами там заморочки, может и не прокатить.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #7  
Старый 23.05.2009, 00:41
Corwin Corwin вне форума
Прохожий
 
Регистрация: 22.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

Цитата:
Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт друг с другом
формат столбца стоит Date\Time(в бд).
Ответить с цитированием
  #8  
Старый 23.05.2009, 11:10
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Сделайте точку останова и посмотрите, что получается в DataModule1.ADOTable1.Filter, фозможно что параметр %s придется еще и кавычками окружать т.к. это предполагается строка.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #9  
Старый 30.05.2009, 00:10
Corwin Corwin вне форума
Прохожий
 
Регистрация: 22.05.2009
Сообщения: 10
Репутация: 10
По умолчанию

Вопрос решен(УРА!).
Всем спасибо за помощь.
Прикрепляю файл-юнит, если кому понадобится.
Вложения
Тип файла: rar Unit6.rar (1.0 Кбайт, 218 просмотров)
Ответить с цитированием
  #10  
Старый 14.11.2010, 14:47
xxbesoxx xxbesoxx вне форума
Новичок
 
Регистрация: 14.11.2010
Сообщения: 63
Репутация: 10
По умолчанию

Corwin Выложите Пожалуйста программа исходникам. Не понял там ничего... Я не понял какои база у тебя .... У меня такои база ,,Access" написал так Посмотрите... на один месяц работает нормально а кагда переходим на втарое месияц не Фильтрует нормально.... Помогите пожалуйста Ребята кто разабрал это ????

http://rapidshare.com/files/43077591...__________.rar
Ответить с цитированием
  #11  
Старый 15.11.2010, 11:04
xxbesoxx xxbesoxx вне форума
Новичок
 
Регистрация: 14.11.2010
Сообщения: 63
Репутация: 10
По умолчанию

Уважаемые Программисты Помогите пожалуйста.... Покажите пример как это разбираться
Ответить с цитированием
  #12  
Старый 16.11.2010, 23:39
xxbesoxx xxbesoxx вне форума
Новичок
 
Регистрация: 14.11.2010
Сообщения: 63
Репутация: 10
По умолчанию

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

А что именно вы хотите? Узнать как сделать SQL-запрос для интервала дат?
Тогда будет примерно так:
Код:
select * from YouTable where YouDate between '01.01.2010' and '31.12.2010'
Для MSSQL возможно придется привести значение к дате и это можно делать так:
Код:
select * from YouTable where YouDate between Cast('01.01.2010' as DateTime) and Cast('31.12.2010' as DateTime)

или так:
Код:
select * from YouTable where YouDate between Convert(DateTime,'01.01.2010',104) and Convert(DateTime,'31.12.2010',104)
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #14  
Старый 17.11.2010, 20:24
xxbesoxx xxbesoxx вне форума
Новичок
 
Регистрация: 14.11.2010
Сообщения: 63
Репутация: 10
По умолчанию

Добры вечер Страдалецъ мне надо... чтобы фильтровать точно Мои пример базы. на Form1 иест 2 DateTimePicker ... База прикрепление наверх... помогите пожалуйста.... как сделать на нево фильтрация или SQL запрос чтобы нормально работал... КАК НЕ РАБОТАЕТ НОРМАЛЬНО

begin
ADOTable1.Filtered:=false;
ADOTable1.Filter:='[Äàòà]>='+QuotedStr(DateToStr(DateTimePicker1.DateTime)) +'and [Äàòà]<='+QuotedStr(DateToStr(DateTimePicker2.DateTime)) +'';
ADOTable1.Filtered:=true;
end;
Ответить с цитированием
  #15  
Старый 17.11.2010, 22:07
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Нет, так работать не будет. Вы сделали ошибку при проектировании структуры таблиц. У вас все поля для даты определены как текстовые. А сортировка текста и даты могут сильно различатся по результату.
Поэтому для начала измените тип полей в таблицах, а уже потом применяйте фильтр.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter