Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.12.09;
Скачать: CL | DM;

Вниз

Обновление набора данных в DBGrid -- требуется помощь   Найти похожие ветки 

 
Сергей Б.   (2002-11-20 12:21) [0]

Здравствуйте, ВСЕМ!

Имеем: IBDataSet, значение SelectSQL которого определяется след. образом: "select * from Table1 where Type = 0", и связанный с ним DBGrid.

Делаем: Устанавливаем значение поля текущей записи Type = 1

Хотим, чтобы данная запись пропала из набора данных, т.е. уже теперь не отображалась в DBGrid, а текущей стала следующая по порядку запись.

Проблема: не получается! :( Т.е. запись пропадает лишь при переоткрытии набора данных, а надо динамически. КАК?


 
ЮЮ ©   (2002-11-20 12:56) [1]

Поставить фильтр, аналогичный условию отбора


 
Сергей Б.   (2002-11-20 13:16) [2]

Кому поставить и как? IBDataSet"у? У него есть св-во Filtered, но как им пользоваться?


 
Наталия ©   (2002-11-20 13:33) [3]

onfilterecords тебе должно помочь


 
Prooksius ©   (2002-11-20 13:46) [4]

У FIBPlus есть такая процедурка - FilterOut

"Remove" the current record from FromDS. (It marks the record deleted without causing a post.)


 
Сергей Б.   (2002-11-20 13:52) [5]

Фильтр попробовал - не помогло. :(

//У FIBPlus есть такая процедурка - FilterOut

Хотелось бы обойтись стандартными IB компонентами...


 
Fareader ©   (2002-11-20 14:00) [6]

2Сергей Б. (20.11.02 13:52)
А ты не пробовал делать Refresh?


 
Сергей Б.   (2002-11-20 14:14) [7]

2 Fareader © (20.11.02 14:00)

Пробовал :) что-то ему безразлично...


 
Fareader ©   (2002-11-20 14:18) [8]

А запрос в Refresh написан?
Проверь чтобы отбиралась именно текущая запись, т.е. оставь только ключевое поле.


 
Сергей Б.   (2002-11-20 14:52) [9]

Запрос написан, естественно отбор по ключевому полю. Ему все равно фиолетово. Измененные данные - да, показывает, а вот исключать по фильтру не хочет, редиска.

Впрочем, проблема решена благодаря подсказке Наталии (какие оказывается талантливые девушки-прграммеры :). Вот такой обработчик помог все сделать:


procedure TClientChild.DS1FilterRecord(DataSet: TDataSet; var Accept: Boolean);
begin
Accept := DataSet["Type"] = 0;
end;


 
Сергей Б.   (2002-11-20 14:57) [10]

Но, вопросы на этом не закончены!!! Теперь требуется сделать обратную операцию: изменить значение Type на 0 и, желательно, не переоткрывать втупую весь DataSet, а постараться лишь подчерпнуть вновь объявившуюся запись. Такое возможно?


 
Fareader ©   (2002-11-20 15:06) [11]

:)


 
Сергей Б.   (2002-11-20 18:06) [12]

Я чувствую, вопрос таки останется без ответа... :(


 
Prooksius ©   (2002-11-20 20:34) [13]

2 Сергей Б. (20.11.02 14:57)
Такого ты не сделаешь без переоткрытия датасета.
Хотя, в FIBPlus есть такая процедурка: FilterIn
Но вообще-то я думаю, что это изврат.
Так что переоткрывай. :(



Страницы: 1 вся ветка

Текущий архив: 2002.12.09;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.018 c
14-28255
Tornado
2002-11-16 14:13
2002.12.09
Народ, помогите плиз...


14-28220
Вадим
2002-11-16 21:00
2002.12.09
Все хорошо! Уже тошнит от этого!


1-28125
kostik78ua
2002-11-28 16:31
2002.12.09
переменные среды


14-28253
Cr@sh
2002-11-17 21:42
2002.12.09
Я с базами данных никогда не работал...


14-28281
Карлсон
2002-11-18 17:43
2002.12.09
противогазы :)