zoukankan      html  css  js  c++  java
  • 在程序中执行脚本

    在处理MSDE一些操作中。需要执行一些SQL脚本。有的是从
    SQLServer 2000中生成的SQL为后缀的脚本。在MSDE中没有企业管理器,
    操作都是在程序中完成的。所以用以下函数来执行SQL脚本。

    //执行一个SQL角本文件,文件只能是ANSI编码的。
    //如果文件是UNICODE编码的话,则会乱码。
    var
      s:string;
      sqltext : string;
      sqlfile : TextFile;
    begin
      if OpenDialog1.Execute then
      begin
        AssignFile(sqlfile, OpenDialog1.FileName);
        FileMode := 0;
        Reset(sqlfile);
        try
          ADOConnection1.BeginTrans;
          while not eof(sqlfile) do
          begin
            Readln(sqlfile, s);
            sqltext:=s;
            while (not eof(sqlfile)) and 
            (uppercase(trim(s))<>'GO') do
            begin
              Readln(sqlfile, s);
              if (uppercase(trim(s))<>'GO') then
                sqltext:=sqltext+' '+s;
            end;
            adoquery1.Close;
            adoquery1.SQL.Clear;
            adoquery1.SQL.Add(sqltext);
            adoquery1.ExecSQL;
          end;
          CloseFile(sqlfile);
          ADOConnection1.CommitTrans;
          application.MessageBox('SQL角本完成!',
            '提示',MB_OK+MB_ICONINFORMATION);
        except
          raise exception.Create('SQL角本执行失败!');
          ADOConnection1.RollbackTrans;
        end;
      end;
    end;

    其中:ADOConnection1,adoquery1,OpenDialog1都是窗口中放置的控件。可以将之设为局部变量,在本函数内创建和消毁。

  • 相关阅读:
    ASP.NET Web API 2 之文件下载
    Windows 查看某个端口号是否被占用
    C# 数据类型之 String(字符串)
    数据表对应关系(一对一、一对多、多对多)
    嫁给程序员的好处,你get到了吗?
    ASP.NET Web API 2 之 HttpRequestMessage 对象
    C# 使用 log4net 记录日志
    Chrome 浏览器快捷键
    C# 获取程序运行时路径
    SpringBoot整合Pagehelper分页插件
  • 原文地址:https://www.cnblogs.com/mingdep/p/2361152.html
Copyright © 2011-2022 走看看