線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1005
推到 Plurk!
推到 Facebook!

使用TADODataSet向数据库添加10000笔记录,速度怎么这么慢?

尚未結案
lovelypp
初階會員


發表:122
回覆:111
積分:46
註冊:2003-02-19

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-12-22 12:48:06 IP:218.104.xxx.xxx 未訂閱
Table的结构为: Ord Int <-------------- 从1增长到10000 Status SmallInt <--------------恒等于-1 使用的是ADO Access, 大概要30秒钟。 各位有无快速的方法?如采用一条SQL语句执行 请高手帮忙解决
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-12-22 14:21:33 IP:63.84.xxx.xxx 未訂閱
您好﹗    方法一﹕
Var
  I : Integer;
begin
  I := 1;
  ADODataSet1.CommandType := cmdTable;
  ADODataSet1.CommandText := 資料表名稱;
  While I < 10000 do
    begin
      ADODataSet1.Close;
      ADODataSet1.Open;
      ADODataSet1.Insert;
      ADODataSet1.FieldByname('Ord_Int').Value := I;
      ADODataSet1.FieldByName('Status_SmallInt').Value := -1;
      ADODataSet1.Post;
      I := I 1;
    end;
end;
方法二﹐因為TADODataSet元件不能使用無回傳值的SQL指令﹐如Insert, Delete等等﹐所以﹐在使用方法二時﹐您可選擇ADOCommand或ADOQuery元件﹕
Var
  I : Integer;
begin
  I := 1;
  While I < 10000 do
    begin
      ADOQuery1.Close;
      ADOQuery1.SQL.Clear;
      ADOQuery1.SQL.Add('Insert Into 資料表名稱 (Ord_Int, ');
      ADOQuery1.SQL.Add('Status_SmallInt) Values (:Ord, :Status)');
      ADOQuery1.ParamByName('Ord').Value := I;
      ADOQuery1.ParamByName('Status').Value := -1;
      ADOQuery1.ExecSQL;
      I := I 1;
    end;
end;
參考看看﹗ ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-12-22 17:22:36 IP:202.39.xxx.xxx 未訂閱
也參考這篇中 Justmade 大大的一些說明: http://delphi.ktop.com.tw/topic.php?TOPIC_ID=27177 --- Everything I say is a lie. @>---
lovelypp
初階會員


發表:122
回覆:111
積分:46
註冊:2003-02-19

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-12-22 21:36:11 IP:218.2.xxx.xxx 未訂閱
问号的关键是如何提速
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-12-25 09:19:07 IP:63.84.xxx.xxx 未訂閱
您好﹗    http://delphi.ktop.com.tw/topic.php?TOPIC_ID=42397 這篇也是您提問的喔 ><>===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-12-25 10:42:24 IP:203.95.xxx.xxx 未訂閱
引言: 问号的关键是如何提速
能有效提升速度的方法就是使用 stored procedure, 但是 access 並不支援, 所以比較沒辦法用這種方法, 但是也可能因為你使用的是 access, 所以本來效能就不高, 所以會造成速度緩慢.
bluecloud
一般會員


發表:0
回覆:1
積分:0
註冊:2003-12-17

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-12-25 11:46:18 IP:203.66.xxx.xxx 未訂閱
引言: Table的结构为: Ord Int <-------------- 从1增长到10000 Status SmallInt <--------------恒等于-1
我將ord 欄位採用access 主索引(識別碼 自動編號)方式,只需要建立好Status欄位,以ADO 寫入只需要14 sec procedure TForm1.Button1Click(Sender: TObject); var I:Integer; str:string; begin try Label1.Caption:=DateTimeToStr(now);//start time ADOConnection1.Connected:=true; with ADOQuery1 do begin Close; sql.Clear; str:='insert into test (status) values (-1)' ; SQL.Add(str); for I := 1 to 10000 do begin ExecSQL; end; Label2.Caption:=DateTimeToStr(now);//End time end; except on E:Exception do begin showmessage(E.Message); halt; end; end; end;
系統時間:2024-07-01 3:13:17
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!