我的申请也有同样的问题。解决方案有点棘手。首先,您必须将 IDENTITY_INSERT 设置为 ON。
procedure TdmUnit1.Identity(Table: string; OnOff: boolean);
var s: string;
begin
if OnOff = true then
s := 'ON'
else
s := 'OFF';
s := 'SET IDENTITY_INSERT ' + '[dbo].[' + Table + '] ' + s;
SQLQuery1.SQL.Clear;
SQLQuery1.SQL.Add(s);
SQLQuery1.ExecSQL;
end;
然后你必须在你的表中寻找最高的索引。您可以通过 OnNewRecord-Event 实现:
procedure TdmUnit1.ClientDataSet1NewRecord(DataSet: TDataSet);
var
s: string;
i: integer;
begin
s := 'SELECT IDENT_CURRENT(''AnyTable'')';
SQLQuery1.SQL.Clear;
SQLQuery1.SQL.Add(s);
SQLQuery1.ExecSQL;
SQLQuery1.Active := true;
i := SQLQuery1.Fields[0].AsInteger;
ClientDataSet1.FieldByName('DB_IDX').AsInteger := i+1;
SQLQuery1.Active := false;
end;
在 ApplyUpdates(0) 之后,您必须关闭 IDENTITY_INSERT。