我使用TSQLConnection通过以下过程从SqlLite导出数据:
Campos := TStringList.Create;
SQLiteConnection.Execute('SELECT * FROM tabela', nil, results);
if not results.IsEmpty then
begin
results.GetFieldNames(Campos);
XLApp1 := createoleobject('excel.application');
XLApp1.Workbooks.Add(xlWBatWorkSheet);
Sheet := XLApp1.Workbooks[1].WorkSheets[1];
linha := 1;
begin
pBar.Max := results.RecordCount;
for coluna := 0 to results.FieldCount - 1 do
Sheet.Cells[1, coluna + 1] := Campos[coluna];
while ( not results.Eof ) do
begin
linha := linha + 1;
for coluna := 0 to results.FieldCount - 1 do
Sheet.Cells[linha, coluna + 1] := results.FieldByName(campos[coluna]).AsString;
results.next;
pBar.Position := pBar.Position + 1;
Application.ProcessMessages;
end; …Run Code Online (Sandbox Code Playgroud)