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

Вниз

Полтергейсты SQL Server или всё "намана"?   Найти похожие ветки 

 
Nikolay M. ©   (2004-04-01 15:50) [40]

Вот только не надо генерить ID на клиенте!
Ты в [34] ссылку читал?


 
31512 ©   (2004-04-01 16:06) [41]

Ага. Спасибо большое. Работает вроде :)


 
31512 ©   (2004-04-01 16:07) [42]

procedure TForm1.ClientDataSet1NewRecord(DataSet: TDataSet);
begin
 if DataSet["ID_ORGANISATION"] = NULL then
   begin
     Beep;
     DataSet["ID_ORGANISATION"] := Random(32768);
   end;
end;


 
Nikolay M. ©   (2004-04-01 16:36) [43]


> DataSet["ID_ORGANISATION"] := Random(32768);

Надеюсь, это только для теста?


 
31512 ©   (2004-04-01 16:53) [44]

Разумеется для теста. Вот только плох этот способ. В клиентском приложении появляется логика базы данных. Приходится в ClientDataSetе добавлять поля в редакторе + для ID_ORGANISATION устанавливать ReadOnly := False. А это не есть гуд.


 
31512 ©   (2004-04-01 17:29) [45]

Ищу у способ обойтись без внесения полей в ClientDataSet в клиентском приложении и без установления ReadOnly := False для ключевого поля.


 
31512 ©   (2004-04-07 10:27) [46]

Вот ещё одно из возможных решений. При этом от identity отказываемся и ключевые поля имеют просто тип int...

.
.
.
var
 .....  
 ID : integer = 0;
 .....

.
.
.
procedure TForm1.ClientDataSet1NewRecord(DataSet: TDataSet);
begin
 DataSet.Fields[0].AsInteger := ID;
end;

procedure TForm1.ClientDataSet1BeforeInsert(DataSet: TDataSet);
begin
ID := DataSet.Fields[0].AsInteger;
Inc(ID);
end;



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

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

Наверх




Память: 0.54 MB
Время: 0.044 c
11-1066893645
Kerk
2003-10-23 11:20
2004.05.02
VCL -> KOL


9-1069597008
mrAld
2003-11-23 17:16
2004.05.02
o fps


3-1080979904
Алексей
2004-04-03 12:11
2004.05.02
DBGrid


8-1075539418
Millennium
2004-01-31 11:56
2004.05.02
скриншот


14-1081331943
Sony
2004-04-07 13:59
2004.05.02
Коды на SONY