Create OleVariant from a Dataset

简介: procedure CreateVarArrayFromDataset(var varResultSet: OleVariant;                                     ADataset : TDataset); var   m : Integer;   nReco...
procedure CreateVarArrayFromDataset(var varResultSet: OleVariant;
                                    ADataset : TDataset);
var
  m : Integer;
  nRecords, nColumns, nCurRec : Integer;
begin
  nRecords := -1;
  nColumns := -1;

  try
    { Create the array... }
    { Set size to 0..m-1 where m equals the number of columns. }
    nColumns := Max(0, ADataset.FieldCount-1);

    { Each item is an array of size (0..n) where n equals the }
    { number of records.}
    { Entry 0 is where we store the column name. }

    nRecords := Max(0, ADataset.RecordCount);

    varResultSet := VarArrayCreate([0, nColumns, 0, nRecords],
                                   varVariant);

    for m := 0 to nColumns do
      varResultSet[m, 0] := ADataset.Fields[m].DisplayLabel;

    { Populate from result set. }
    ADataset.First;
    nCurRec := 1; { Current record number. }
    while not ADataset.Eof do begin
      { Put in field values. }
      for m := 0 to nColumns do
        varResultSet[m, nCurRec] := ADataset.Fields[m].Value;

      ADataset.Next;
      Inc(nCurRec);
    end;
  except
    on E: Exception do
      raise Exception.Create('CreateVarArrayFromDataset() - ' +
                              IntToStr(nRecords) +
                             ' rec,'+IntToStr(nColumns)
                             +'cols,'+E.Message);
  end;
end;
目录
相关文章
|
SQL 分布式计算 安全
Dataset 介绍_Dataset 是什么 | 学习笔记
快速学习 Dataset 介绍_Dataset 是什么
300 0
Dataset 介绍_Dataset 是什么 | 学习笔记
|
SQL 数据库
CREATE TABLE
CREATE TABLE
164 0
|
开发工具
|
算法框架/工具 iOS开发 异构计算
caffe: test code for PETA dataset
test code for PETA datasets .... 1 #ifdef WITH_PYTHON_LAYER 2 #include "boost/python.hpp" 3 namespace bp = boost::python; 4 #endif 5 ...
|
XML 缓存 数据库
DataSet用法详细 转
一、特点介绍1、处理脱机数据,在多层应用程序中很有用。2、可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法。3、处理分级数据4、缓存更改5、XML的完整性:DataSet对象和XML文档几乎是可互换的。
904 0
|
SQL 监控
CREATE TABLE TEST_A AS SELECT * FROM TEST_B
查看数据库模式:   SQL> connect /as sysdba Connected. SQL> select name,log_mode from v$database;   N...
1057 0
C# DataSet.RejectChanges 方法
        回滚自创建 DataSet 以来或上次调用 DataSet.AcceptChanges 以来对其进行的所有更改。         调用 DataSet.RejectChanges 以针对由 DataSet 包含的所有 DataTable 对象调用 DataTable.RejectChanges 方法。         由 DataSet 包含的每个 DataRow 对象
1392 0