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

Вниз

Перемещение в таблице   Найти похожие ветки 

 
Ирина   (2005-07-22 09:52) [0]

Просьба не закрывать сразу мой вопрос, я не могу получить ответ. При нажатии кнопки надо поместить курсор на определенную запись в таблице, причем местоположение этой записи меняется, т.к. перед ней время от времени добавляются записи. (Это справочник, состоящий из двух разделов. Каждый раздел пополняется периодически. Надо устанавливать курсор при нажатии кнопки на начало второго раздела)


 
Anatoly Podgoretsky ©   (2005-07-22 10:01) [1]

Locate


 
Digitman ©   (2005-07-22 10:11) [2]


> на определенную запись в таблице


каков же критерий "определенности" ?


 
Digitman ©   (2005-07-22 10:19) [3]

var
 bkmrk: TBookmark;
..

//получим закладку на нужную (текущую) запись
bkmrk := DataSet.GetBookmark;
try

//вставляем, удаляем, обновляем разные записи
//"гуляем" по НД туда-сюда как нам вздумается

 DataSet.Insert;
 ..
 DataSet.Post;

 Dataset.First;
..
 Dataset.Last;
.. и т.д. и т.п.

finally
//нагулялись вдоволь
//теперь возвращаемся к той записи, с которой ушли
DataSet.GotoBookmark(bkmrk);
//и не забываем уничтожить закладку, если она нам более не нужна
DataSet.FreeBookmark(bkmrk);
end;


 
msguns ©   (2005-07-22 10:52) [4]

Метод Digitman ©   (22.07.05 10:19) [3] имеет один недостаток: вероятность утери букмаркой своей валидности, если надо перечитать датасет при многопользовательском доступе.
Поэтому надо либо включить GoToBookMark в защищенный блок, либо проверять ее валидность, либо (ИМХО-лучше всего) использовать ID записей, который можно сохранить в тэге детасета перед "прогулкой"


 
msguns ©   (2005-07-22 10:52) [5]

Удалено модератором


 
evvcom ©   (2005-07-22 11:05) [6]


> Просьба не закрывать сразу мой вопрос

Ничего удивительного. Прошлые вопросы были с неоформленной темой.


 
зигмунд .Ф ©   (2005-07-23 23:45) [7]

отключаешь прорисовку таблицы (для скорости)

while not tabl.Eof do
if tabl.key.AsInteger=x then exit else
tabl.Next;

и вклячаешь ее обратно...

про TBookmark уже писали


 
msguns ©   (2005-07-24 09:18) [8]

>зигмунд .Ф ©   (23.07.05 23:45) [7]

Так делать НЕ надо.


 
RusLAN_   (2005-07-25 15:26) [9]

заведите отдельное поле
и указывайте в нем номер раздела к которому принадлежит запись
И вообще запись лучше иденфицировать по значению ключевого поля, а не по номеру позиции.

>зигмунд .Ф ©   (23.07.05 23:45) [7]
не путайте людей :))
в таких случаях давайте советы как в [1]



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

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

Наверх




Память: 0.48 MB
Время: 0.024 c
4-1121495304
Михаил(Киров)
2005-07-16 10:28
2005.09.04
Блокировка клавиатуры


3-1122369826
Игорь М.
2005-07-26 13:23
2005.09.04
восстановление подключения с IterBase server ом


1-1124140320
Витёк
2005-08-16 01:12
2005.09.04
Обработка события входа курсора мыши на компонент и выхода!


14-1123512095
root
2005-08-08 18:41
2005.09.04
Очень уж щикотливая тема :-)


14-1123569542
boriskb
2005-08-09 10:39
2005.09.04
Майкл Линн против Cisco