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

Вниз

Refresh одной записи в ClientDataSet   Найти похожие ветки 

 
alsn   (2002-05-29 15:36) [0]

Здравсвуйте.
Использую TClientDataSet + TDataSetProvider + TAdoDataSet + MSSQL.
Источник данных для AdoDataSet - весьма долгоиграющая хранимая процедура.
Вопрос: Как обновить ТОЛЬКО ОДНУ запись в ClientDataSet. В MSSQL для этого
все подготовлено: создана отдельная процедура, возвращающая только одну
запись в рекордсете.
Заранее спасибо.


 
Romkin ©   (2002-05-29 16:08) [1]

Положи TClientDataSet в RemoteDataModule и собирай там то, что нужно клиенту, а провайдера цепляй к этому датасету


 
Автор   (2002-05-29 17:02) [2]

Возможно я не достаточно подробно все описал. Итак, есть две процедуры в MSSQL. Одна отработав ~2 минуты возвращает ~ 5 тыс. записей. Вторая - только одну из этих 5 тысяч.
В клиенте: TAdoDataSet + TDataSetProvider + TClientDataSet. Все в одном exe файле. Никаких RemoteDataModule и MIDAS-серверов тут нет.
Теперь следующая ситуация: Одна (или несколько) из упомянутых выше 5-и тысяч записей изменилась. Мое приложение знает ID этой записи (этих записей). Неважно где это произошло: в другом окне, из другого приложения или вообще с другого компьютера. Важно другое: что нужно сделать в TDataSetProvider-е и/или в TClientDataSet-е чтобы эта запись обновилась. На сервере для этого создана процедура, которая по ID записи выдаст все поля из ее таблицы.

Заранее Списибо.

P.S. Если сделать ClientDataSet.RefreshRecord, то это приведет к повторному переоткытию источника данных для TDataSetProvider-а, т.е. к повторному вызову первой процедуры и повторной прокачке 5 тыс. записей.


 
oss   (2002-05-29 17:46) [3]

А если нет "RemoteDataModule и MIDAS-серверов" то для чего
TDataSetProvider + TClientDataSet ??
А для TAdoDataSet попробуй курсор на стороне сервера поставить
и апдейт по условию WHERE на DataSetProvidere. либо делать Requery у клиетдатасета, тока прочто про Requery в хелпе :)


 
Romkin ©   (2002-05-29 18:17) [4]

Тогда просто бери эту одну запись в другой TADOQuery, потом сливай ручками со своей cds, и вызывай MergeChangeLog (предупреждаю - после этой команды ChangeCount = 0, так что если были изменения...)


 
Sam ©   (2002-06-03 19:05) [5]

Resync


 
Sam ©   (2002-06-03 19:13) [6]

ADODataSet1.Recordset.Resync


 
Alex Ignatenko   (2002-06-04 13:41) [7]

Куда то пропал мой первый ответ. Ну ладно, повторю еще раз.

Для обновления одной записи рекордсета нужно использовать динамическое свойство ResyncCommand. Подробнее смотри MSDN или статью об АДО http://www.delphikingdom.com/helloworld/ado03.htm



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

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

Наверх




Память: 0.48 MB
Время: 0.015 c
1-88902
voodoo_alex
2002-06-13 21:59
2002.06.27
Как идеологически верней ?


1-88872
Igit
2002-06-14 12:55
2002.06.27
Т point 2 integer


3-88701
unreger
2002-05-27 05:54
2002.06.27
VB+MSSQL - > Delphi6+MSSQL, переход


14-89005
BigBadMutuh
2002-05-23 20:24
2002.06.27
Возраст


6-88976
Ghost.
2002-04-17 13:30
2002.06.27
По поводу кодировок...