首先用ADOQuery控件完成对数据库的查询,并已经在DBGrid控件中显示出来,怎样把这些数据保存呢,不想一条记录一条记录地保存,速度太慢了????
解决方案 »
- Serversocket 服务,ClientSocket已经连接/ 请教`````````````````
- DSPack2.33 for D5 安装问题
- 模态窗体关闭问题,大家救救急!
- 关于delphi、fastReport的基础问题。。。请大家帮忙
- WinSock问题:写了一个自定义超时连接的function.可不知道问题出在哪?走过路过不要错过阿,可能是很简单的问题
- 大家又没遇到这样的问题呀????
- 我写的一个小程序,有些小小的问题,求助大家了,给分决不食言
- 如何把String类型参数传递给DLL?
- 如何得知当前IE窗口的URL地址和TITLE
- 高难度的问题!!!
- 一个数据库插入语句的问题,比较奇怪
- 怎样让TDataTimePicker控件只显示日期
ADOQuery1.Post
统一提交:ADOQuery1.UpdateBatch;
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, DB, ADODB, Grids, DBGrids,comobj, StdCtrls;type
TForm1 = class(TForm)
Button1: TButton;
DataSource1: TDataSource;
DBGrid1: TDBGrid;
ADOQuery1: TADOQuery;
ADOConnection1: TADOConnection;
DataSource2: TDataSource;
DBGrid2: TDBGrid;
ADOQuery2: TADOQuery;
procedure Button1Click(Sender: TObject);
private
{ Private declarations }
procedure CopyDbDataToExcel(Args: array of const);
public
{ Public declarations }
end;var
Form1: TForm1;implementation{$R *.dfm}procedure TForm1.CopyDbDataToExcel(Args: array of const);
var
iCount, jCount: Integer;
XLApp: Variant;
Sheet: Variant;
I: Integer;
begin
Screen.Cursor := crHourGlass;
if not VarIsEmpty(XLApp) then
begin
XLApp.DisplayAlerts := False;
XLApp.Quit;
VarClear(XLApp);
end; try
XLApp:=CreateOleObject('Excel.Application');
except
Screen.Cursor := crDefault;
Exit;
end; XLApp.WorkBooks.Add;
XLApp.SheetsInNewWorkbook := High(Args) + 1; for I := Low(Args) to High(Args) do
begin
XLApp.WorkBooks[1].WorkSheets[I+1].Name := TDBGrid(Args[I].VObject).Name;
Sheet:= XLApp.Workbooks[1].WorkSheets[TDBGrid(Args[I].VObject).Name]; if not TDBGrid(Args[I].VObject).DataSource.DataSet.Active then
begin
Screen.Cursor := crDefault;
Exit;
end; TDBGrid(Args[I].VObject).DataSource.DataSet.first;
for iCount := 0 to TDBGrid(Args[I].VObject).Columns.Count - 1 do
Sheet.Cells[1, iCount + 1] :=
TDBGrid(Args[I].VObject).Columns.Items[iCount].Title.Caption; jCount := 1;
while not TDBGrid(Args[I].VObject).DataSource.DataSet.Eof do
begin
for iCount := 0 to TDBGrid(Args[I].VObject).Columns.Count - 1 do
Sheet.Cells[jCount + 1, iCount + 1] :=
TDBGrid(Args[I].VObject).Columns.Items[iCount].Field.AsString; Inc(jCount);
TDBGrid(Args[I].VObject).DataSource.DataSet.Next;
end;
XlApp.Visible := True;
end;
Screen.Cursor := crDefault;
end;procedure TForm1.Button1Click(Sender: TObject);
begin
CopyDbDataToExcel([dbgrid1,dbgrid2]);
end;end.
讲解讲解了