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

Вниз

MIDAS   Найти похожие ветки 

 
Polevi ©   (2001-12-06 18:11) [0]

Пишу 3-звенку. MS SQL через ADO
ClientDataset.Insert;
ClientDataset.FieldByName("...").AsString="some value";
ClientDataset.Post;
ClientDataset.ApplyUpdates(0);

В таблице есть AutoInc поле - проблема в том что в ClientDataset для свежедобавленной записи значение этого поля не определено. Как мне его получить?

DatasetProvider.Options:=[poAutoRefresh] не помогает :(

Можно конечно делать ClientDataset.Refresh после ClientDataset.ApplyUpdates но может быть есть более элегантное решение?


 
Tonie ©   (2001-12-07 11:41) [1]

Попробуй Query поставить
AutoRefresh = true
а для поля и в Query и в ClientDataSet
FieldKind = fkInternalCalc
AutoGenerateValue = arAutoInc
Но возможно что это только с BDE работает


 
Axel ©   (2001-12-07 12:51) [2]

Same troubles
See help for TBaseProvider.BeforeUpdateRecord
...
Manually apply updates that the provider can’t handle. For example, the provider can’t generate the appropriate SQL when the data results from a multi-table join and more than one table must be updated. Write code in the event handler to apply the update and then set the Applied parameter to True so that the provider does not generate an error.
...
I"ve not found anything better :((


 
Axel ©   (2001-12-07 12:53) [3]

Or set YourDataSetProvider.ResolveToDataSet = False


 
Polevi ©   (2001-12-07 14:35) [4]

2Tonie ©
AutoRefresh есть у TDBDataset (наследник TBDEDataset) - мне не подходит :(

2Axel
ResolveToDataSet = False не помогает

И не совсем понятно, чем может помочь BeforeUpdateRecord - это событие позволяет управлять данными, которые будут записаны в базу - я не вижу способа обновить ClientDataset с его помощью ...




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

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

Наверх




Память: 0.47 MB
Время: 0.008 c
1-28511
VadX
2001-12-21 15:29
2002.01.10
Вопрос


6-28526
Diamond Dog
2001-10-14 17:21
2002.01.10
Отключение компьютера по сети.


14-28530
Sir Alex
2001-11-12 19:37
2002.01.10
клиент DMFC & Sources & CVS


1-28492
Delphimun
2001-12-21 14:24
2002.01.10
Как изменить букву на несколько букв вперёд(по алфавиту)?


3-28423
Boss2
2001-12-08 20:20
2002.01.10
TreeView/БД