• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

Delphi操作SQL插入一万条数据三种方式速度测试

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, DB, ADODB, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    btn1: TButton;
    ADOConnection1: TADOConnection;
    ADOQuery1: TADOQuery;
    ADOCommand1: TADOCommand;
    Button2: TButton;
    procedure Button1Click(Sender: TObject);
    procedure btn1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
    procedure ExecSql(SqlSentence:String);
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.ExecSql(SqlSentence:String);
begin
    with ADOQuery1 do
    begin
      Close;
      SQL.Clear();
      SQL.Add(SqlSentence);
      ExecSQL;
    end;
end;

procedure TForm1.Button1Click(Sender: TObject);
var I:integer;
    SqlStr,MsgStr:string;
    ID,Name:string;
    Time:Cardinal;
begin
  // 一条一套插入1万条数据 耗时大约86秒
  Time:=GetTickCount;
  for i:=1 to 10000 do
  begin
    Name:= QuotedStr('easyboot'+InttoStr(i));
    SqlStr:=Format(' insert into MyTest (Name) values (%s)',[Name]);
    ExecSql(SqlStr );
  end;
  Time:=GetTickCount-Time;
  MsgStr:=Format('Time %d ',[Time]);
  ShowMessage(MsgStr);
end;

procedure TForm1.btn1Click(Sender: TObject);
var I,x:integer;
    SqlStr,MsgStr:string;
    ID,Name:string;
    Time:Cardinal;
begin
  // 一次插入1万条数据 耗时大约19秒
  Time:=GetTickCount;
  for i:=1 to 10000 do
  begin
    Name:= QuotedStr('easyboot'+InttoStr(i));
    SqlStr:=SqlStr+Format(' insert into MyTest (Name) values (%s)  ',[Name]);

  end;
  ExecSql(SqlStr );
  Time:=GetTickCount-Time;
  MsgStr:=Format('Time %d ',[Time]);
  ShowMessage(MsgStr);
end;

procedure TForm1.Button2Click(Sender: TObject);
var I,x:integer;
    SqlStr,MsgStr:string;
    ID,Name:string;
    Time:Cardinal;
begin
  // 一次插入1万条数据 耗时大约4秒
  Time:=GetTickCount;

  for i:=1 to 10000 do
  begin
    Name:= QuotedStr('easyboot'+InttoStr(i));
    SqlStr:=SqlStr+ Format(' insert into MyTest (Name) values (%s)  ',[Name]);

  end;
  ADOConnection1.Open;
  ADOConnection1.BeginTrans;
  ADOCommand1.CommandText:=SqlStr;
  ADOCommand1.Execute();
  ADOConnection1.CommitTrans;

  Time:=GetTickCount-Time;
  MsgStr:=Format('Time %d ',[Time]);
  ShowMessage(MsgStr);
end;

end.
--------------------- 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
delphiassignfile用法发布时间:2022-07-18
下一篇:
Delphi设置WebBrowser代理服务器与UserAgent发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap