Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > Delphi программирование > БД в Delphi
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 18.05.2014, 19:02   #1
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
Восклицание Фильтрация в DBGrid по дате кликом на MonthCalendar

Здравствуйте, знатоки Delphi. Я начинающий программист и не сталкивался с этим раньше. Есть форма, на которой расположены DBGrid (DBGridEh) и MonthCalendar. Мне нужно как-то сделать так, чтобы кликом по дате в календаре в таблице оставались только записи, содержащие именно эту дату, ну и остальные записи соответствующие этой дате (дата, время, врач, фио пациента, процедура). Не подскажите как это осуществить, а то пока ничего толкового в инете найти не могу?
Corvus046 вне форума Ответить с цитированием
Старый 18.05.2014, 19:10   #2
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Table или Query используешь? Какая СУБД?
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 18.05.2014, 19:16   #3
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
По умолчанию

Цитата:
Сообщение от Stilet Посмотреть сообщение
Table или Query используешь? Какая СУБД?
СУБД - Microsoft SQL Server. Для связи с ним использую ADOConnection, ADOTable, DataSourсe. Разместил их на Data Module.

Последний раз редактировалось Corvus046; 18.05.2014 в 19:20.
Corvus046 вне форума Ответить с цитированием
Старый 18.05.2014, 19:49   #4
Stilet
Белик Виталий :)
Старожил
 
Аватар для Stilet
 
Регистрация: 23.07.2007
Сообщений: 57,097
По умолчанию

Ага, ясно. Тогда наверное приемлемее будет описать событие OnFilterRecord для ADOTable примерно так:
Код:
procedure TForm1.SQLQuery1FilterRecord(DataSet: TDataSet; var Accept: Boolean);
begin
 Accept:=DataSet.FieldByName('Дата').AsDateTime=MonthCalendar.Date;
end;
Ну и в событии MonthCalendar типа OnChange или любом срабатывающем при изменении написать:
Код:
 ADOTable.Filtered:=false;
 ADOTable.Filtered:=true;
чтоб запустить фильтрацию.
I'm learning to live...
Stilet вне форума Ответить с цитированием
Старый 18.05.2014, 19:57   #5
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
По умолчанию

Так событие OnFilterRecord описать в ADOTable или в SQLQuery, как у вас? Просто у меня SQLQuery так-то нет в проекте. Или вы предлагаете мне SQLQuery тоже поместить на форму и связать его через событие DataSource к компоненту DataSource1, где будут находиться все данные с датами и т.п.? Хотя в SQLQuery я вообще не вижу такого события, но удивился, почему у вас в названии процедуры он упоминается

Последний раз редактировалось Corvus046; 18.05.2014 в 20:00.
Corvus046 вне форума Ответить с цитированием
Старый 18.05.2014, 20:23   #6
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
По умолчанию

Я попробовал как вы посоветовали и написал так:

procedure TZayavki.ADOTable1FilterRecord(Data Set: TDataSet;
var Accept: Boolean);
begin
Accept:=DataSet.FieldByName('Data') .AsDateTime=MonthCalendar1.Date;
end;

procedure TZayavki.MonthCalendar1Click(Sender : TObject);
begin
ADOTable1.Filtered:=False;
ADOTable1.Filtered:=True;

Но потом, при клику по календарю выскакивает такая ошибка:
Project raised exception class EConvertError with messege "2014-05-21' is not a valid date and time'.
Corvus046 вне форума Ответить с цитированием
Старый 18.05.2014, 20:34   #7
Аватар
Старожил
 
Аватар для Аватар
 
Регистрация: 17.11.2010
Сообщений: 18,922
По умолчанию

Поле Data небось символьного типа?
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
Аватар вне форума Ответить с цитированием
Старый 18.05.2014, 20:40   #8
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
По умолчанию

Цитата:
Сообщение от Аватар Посмотреть сообщение
Поле Data небось символьного типа?
В таблице в SQL Server Имя столбца - "Data", Тип данных - "date".
Corvus046 вне форума Ответить с цитированием
Старый 18.05.2014, 20:48   #9
Аватар
Старожил
 
Аватар для Аватар
 
Регистрация: 17.11.2010
Сообщений: 18,922
По умолчанию

А сделать его datetime есть возможность?
По-моему как widestring такие поля в дельфи передаются и его нужно правильно в datetime сконвертировать. Лучше сделать в базе datetime
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию

Последний раз редактировалось Аватар; 18.05.2014 в 20:57.
Аватар вне форума Ответить с цитированием
Старый 18.05.2014, 21:09   #10
Corvus046
Пользователь
 
Регистрация: 18.05.2014
Сообщений: 14
По умолчанию

Цитата:
Сообщение от Аватар Посмотреть сообщение
А сделать его datetime есть возможность?
По-моему как widestring такие поля в дельфи передаются и его нужно правильно в datetime сконвертировать. Лучше сделать в базе datetime
Исправил, ошибки теперь нет, но тыкание по календарю ничего не изменяет
Corvus046 вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
фильтрация по дате delfin07 C++ Builder 0 04.06.2012 09:34
Фильтрация по дате в запросе Santosh Microsoft Office Access 1 18.08.2010 01:04
как соеденить DBGrid and MonthCalendar? Милана666 БД в Delphi 24 20.05.2010 01:36
фильтрация по текущей дате ahvahsky2008 БД в Delphi 5 04.05.2010 05:30