Wod*_*dzu 3 delphi field ado dataset calculated-field
之情况:
我想在运行时向给定(任意)数据集添加计算字段.除了执行DataSet.Open方法之外,我不知道获取数据集结构的任何其他方法.
但是该Open方法导致至少一行数据需要从服务器转移到客户端.然后我需要关闭DataSet,添加字段并重新打开它.在我看来,这是一个不必要的开销.有没有更好的方法呢?请注意,我不希望能够为任何数据集添加计算字段,并且在打开之前我不知道它的结构.
在伪代码中它看起来像这样:
DataSet.Open;
DataSet.Close;
RecreateFieldsStructure;
AddCalculatedField;
DataSet.Open;
Run Code Online (Sandbox Code Playgroud)
谢谢你的时间.
Tih*_*uan 12
您可以使用DataSet.FieldDefs.Update方法.这仍将涉及一些数据传输,但不会获取任何行.您可以在TDataSet的BeforeOpen事件中调用此方法,并在其中添加计算字段.
这是一个适合我的简短示例:
procedure TDataModule.cdsExampleBeforeOpen(DataSet: TDataSet);
var I: Integer;
TmpField: TDateTimeField;
begin
// Get field definitions from the server
DataSet.FieldDefs.Update;
// Add calculated field
TmpField := TDateTimeField.Create(DataSet);
with TmpField do
begin
Name := 'Date';
FieldName := 'Date';
DisplayLabel := 'Date';
DisplayFormat := 'ddd ddddd';
Calculated := True;
end;
TmpField.DataSet := DataSet;
// Create fields from field definitions
for I := 0 to DataSet.FieldDefs.Count - 1 do
DataSet.FieldDefs[I].CreateField(DataSet);
end;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2439 次 |
| 最近记录: |