自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

批量執(zhí)行SQL語句的示例

數(shù)據(jù)庫 SQL Server
如果需要在程序中批量執(zhí)行SQL語句,應(yīng)該如何操作呢?下文就將教您如何批量執(zhí)行SQL語句,供您參考。

在項目中,經(jīng)常會遇到需要批量執(zhí)行SQL語句的情況,下面將為您示例說明批量執(zhí)行SQL語句的方法,希望對教您學(xué)習(xí)SQL語句有所幫助。

當(dāng)然,我們更想在程序中去執(zhí)行這些語句,而不是再去打開查詢分析器。

當(dāng)我們要在程序中批量執(zhí)行SQL語句時,需要明白AdoConnection,或AdoQuery(假設(shè)我們使用ADO組件)可以執(zhí)行的語句有什么要求。

1、在查詢分析器里,一條SQL語句,我們可以直接寫成

Select * from aTable where ID=123

或者

Select * from aTable where ID=123;

這兩條語句結(jié)果相同。不同的地方只是第二條多了一個“;”,用來表示一條語句結(jié)束。

2、在查詢分析器里,多條SQL語句的寫法

insert into aTable(Field1,Field2) values( '值一','值二')

go

這里的 go 表示一個批處理

根據(jù)以上兩點,我們可以看出,我們要在程序中批量執(zhí)行SQL語句,需要判斷一個完整的操作包含幾條語句,這些語句是不是可以單獨執(zhí)行等。

下面是一個示例程序(程序中不涉及到Select操作)
 

  1. unit BatchSQL;   
  2. {   
  3.    批量執(zhí)行SQL腳本   
  4.    E-main: goldli@163.com   
  5. }   
  6. interface   
  7. uses   
  8.   SysUtils,ADODB,Classes;   
  9.  
  10. type   
  11.    TOnException = procedure(const E: Exception) of object;   
  12.    TOnSQLExecute = procedure(const strSQL: string;const RowsAffected:Integer) of object;   
  13.  
  14. type   
  15.   {完整的SQL語句}   
  16.   TSQLString = class   
  17.   private   
  18.     FBuffer:string;   
  19.     FSQL:TStrings;   
  20.     FChanged:Boolean;   
  21.     function GetSQL:string;   
  22.   public   
  23.     constructor Create;   
  24.     destructor  Destroy;override;   
  25.     procedure   Append(const StrSQL:string);   
  26.     property    SQL:string read GetSQL;   
  27.   end;   
  28.  
  29.   TBatchSQL = class   
  30.   private   
  31.     FConnection:TADOConnection;   
  32.     FSQLList:TList;   
  33.     FOnException:TOnException;   
  34.     FOnSQLExecute:TOnSQLExecute;   
  35.   public   
  36.     constructor Create(const AConnection:TADOConnection);   
  37.     destructor  Destroy;override;   
  38.     property  Connection:TADOConnection write FConnection;   
  39.     procedure LoadFromFile(const FileName:string);   
  40.     procedure Execute;   
  41.     property  OnException:TOnException write FOnException;   
  42.     property  OnSQLExecute:TOnSQLExecute write FOnSQLExecute;   
  43.   end;   
  44.  
  45. implementation   
  46.  
  47. { TSQLString }   
  48.  
  49. procedure TSQLString.Append(const StrSQL: string);   
  50. begin   
  51.   FSQL.Append(StrSQL);   
  52.   FChanged:=True;   
  53. end;   
  54.  
  55. constructor TSQLString.Create;   
  56. begin   
  57.   FSQL:=TStringList.Create;   
  58. end;   
  59.  
  60. destructor TSQLString.Destroy;   
  61. begin   
  62.   FSQL.Free;   
  63.   inherited;   
  64. end;   
  65.  
  66. function TSQLString.GetSQL: string;   
  67. begin   
  68.   if FChanged then   
  69.   begin   
  70.     FBuffer:=FSQL.Text;   
  71.     FChanged:=False;   
  72.   end;   
  73.   Result:=FBuffer;   
  74. end;   
  75.  
  76. { TBatchSQL }   
  77.  
  78. constructor TBatchSQL.Create(const AConnection: TADOConnection);   
  79. begin   
  80.   if Assigned(AConnection) then   
  81.     FConnection:=AConnection;   
  82.   FSQLList:=TList.Create;   
  83. end;   
  84.  
  85. destructor TBatchSQL.Destroy;   
  86. var   
  87.   i:Integer;   
  88. begin   
  89.   FConnection:=nil;   
  90.   for i:FSQLList.Count -1 downto 0 do   
  91.     TSQLString(FSQLList.Items[i]).Free;   
  92.   FSQLList.Free;   
  93.   inherited;   
  94. end;   
  95.  
  96. procedure TBatchSQL.Execute;   
  97. var   
  98.   i:Integer;   
  99.   Qry:TADOQuery;   
  100.   SQLString:TSQLString;   
  101. begin   
  102.   Assert(Assigned(FConnection),'數(shù)據(jù)庫連接不能為nil.');   
  103.   Assert(FSQLList.count > 0,'請先加載SQL文件.');   
  104.   FConnection.LoginPrompt:=False;   
  105.   FConnection.Connected:=True;   
  106.   Qry:=TADOQuery.Create(nil);   
  107.   with Qry do   
  108.   begin   
  109.     Connection:=FConnection;   
  110.     Prepared:=True;   
  111.     for i:=0 to FSQLList.Count -1 do   
  112.     begin   
  113.       SQLString:=TSQLString(FSQLList.Items[i]);   
  114.       SQL.Clear;   
  115.       SQL.Add(SQLString.SQL);   
  116.       try   
  117.         ExecSQL;   
  118.         if Assigned(FOnSQLExecute) then   
  119.           FOnSQLExecute(SQLString.SQL,RowsAffected);   
  120.       except   
  121.         on E:Exception do   
  122.           if Assigned(FOnException) then   
  123.             FOnException(E)   
  124.           else   
  125.             raise Exception.Create('SQL語句出錯:' + sLineBreak + SQLString.SQL);   
  126.       end;   
  127.     end;   
  128.     Free;   
  129.   end;    
  130. end;   
  131.  
  132. procedure TBatchSQL.LoadFromFile(const FileName: string);   
  133. var   
  134.   SqlStr,Tmp:string;   
  135.   F:TextFile;   
  136.   SQLString:TSQLString;   
  137. begin   
  138.   Assert(FileExists(FileName),'SQL文件不存在,不能加載.');    
  139.   AssignFile(F,FileName);   
  140.   Reset(f);   
  141.   Repeat   
  142.     Readln(F,Tmp);   
  143.     if Tmp='GO' then   
  144.     begin   
  145.       SQLString:=TSQLString.Create;   
  146.       SQLString.Append(SqlStr);   
  147.       FSQLList.Add(SQLString);   
  148.       SqlStr:='';   
  149.       Tmp:='';   
  150.     end;   
  151.     SqlStrSqlStr:=SqlStr + Tmp;   
  152.   Until eof(F);   
  153.   Closefile(F);   
  154. end;   
  155.  
  156. end. 

 

 

【編輯推薦】

修改SQL主鍵約束的SQL語句寫法

教您使用SQL語句修改SQL主鍵

逐條更新數(shù)據(jù)的SQL語句寫法

對存儲過程代替SQL語句的討論

測試SQL語句執(zhí)行時間的方法

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-09-08 16:17:37

SQL循環(huán)語句

2010-09-17 09:35:51

SQL中if語句

2010-09-03 14:47:50

SQLSELECT語句

2024-12-26 08:16:26

2010-04-29 14:06:40

Oracle SQL

2021-07-28 07:22:40

SQL順序Hive

2019-11-06 09:30:35

SQL查詢語句數(shù)據(jù)庫

2010-09-25 16:21:41

SQL語句

2010-11-04 09:43:46

LINQ to SQL

2011-07-21 13:44:52

MySQLmysqldumpsl

2013-10-29 16:27:23

MySQLSQL語句

2010-03-31 15:03:54

Oracle執(zhí)行

2023-11-15 20:24:54

數(shù)據(jù)庫SQLGo語言

2010-01-19 17:03:25

VB.NET可執(zhí)行語句

2022-07-28 09:13:30

MySQL數(shù)據(jù)庫

2010-09-06 13:17:19

SQL Server語句

2010-09-07 11:41:24

SQL語句

2011-03-21 15:39:31

LAMPPHPSQL

2010-09-08 15:00:03

SQL語句執(zhí)行

2010-11-04 13:55:26

DB2 SQL腳本批量
點贊
收藏

51CTO技術(shù)棧公眾號