当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-01-25 23:11:00  来源:本站整理

<b>批量履行SQL语句的示例</b>[MSSQL防范]

赞助商链接



  本文“<b>批量履行SQL语句的示例</b>[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

在项目中,常常会碰到需求批量履行SQL语句的情形,下面将为您示例阐明批量履行SQL语句的办法,但愿对教您学习SQL语句有所帮忙.

当然,我们更想在程序中去履行这些语句,而不是再去翻开查询解析器.

当我们要在程序中批量履行SQL语句时,需求懂得AdoConnection,或AdoQuery(假定我们利用ADO组件)可以履行的语句有什么要求.

1、在查询解析器里,一条SQL语句,我们可以直接写成

Select * from aTable where ID=123

大概

Select * from aTable where ID=123;

这两条语句后果相同.差别的地方只是第二条多了一个“;”,用来表示一条语句完毕.

2、在查询解析器里,多条SQL语句的写法

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

go

这里的 go 表示一个批处理

按照以上两点,我们可以看出,我们要在程序中批量履行SQL语句,需求判断一个完好的操作包含几条语句,这些语句是不是可以单独履行等.

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

  1. unit BatchSQL;   
  2. {   
  3.    批量履行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),'数据库衔接不能为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. 
<
  以上是“<b>批量履行SQL语句的示例</b>[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .