C# 調用並執行SQL指令檔

來源:互聯網
上載者:User

原文串連:http://www.cnblogs.com/long-gengyun/archive/2012/05/25/2517954.html

突然接到leader的任務,為營運寫個小工具,給一個參數然後調用一個sql指令檔並替換器內部某個參數,然後執行.

於是工作開始了...

首先想到的是能讓C#程式直接執行sql指令檔,類似SSMS直接開啟sql檔案並執行一樣,搜尋了一下結果還真有,不過需要借用mssql的幾個類庫及命名空間:

Microsoft.SqlServer.ConnectionInfo.dll

Microsoft.SqlServer.Smo.dll

--------------------------------------------

using Microsoft.SqlServer.Management.Common;

using Microsoft.SqlServer.Management.Smo;

這裡有一個小插敘,對於vs2008裡可以直接引用這個這兩個類庫,但在vs2010裡的引用就無法找到這兩個類庫了(不知道微軟是怎麼考慮的)

還好我電腦vs2008和vs2010都安裝了

不過我還是避易就難的講一下,vs2010在引用裡無法找到這兩個類庫,那我們就想辦法找到它,首先我電腦安裝了mssqlserver2008 ,

我去X:\Program Files\Microsoft SQL Server\100\SDK\Assemblies 找到

Microsoft.SqlServer.ConnectionInfo.dll

Microsoft.SqlServer.Smo.dll

Microsoft.SqlServer.Management.Sdk.Sfc.dll(這個一定要考到你的程式目錄,但你可以不引用)

然後手動添加應用,第三個dll一定要引用,不然會報錯

下面看代碼:

//補卡操作
         private void PatchCard()
         {
             string path = System.Environment.CurrentDirectory;
             string CardNo = txtCardNo.Text.Trim();
             string connectonstring=ConfigurationManager.AppSettings["connectionString"].ToString();
             if(CardNo==null||CardNo=="")
             {
                 MessageBox.Show("卡號不可為空!");
                 return;
             }
             if(!path.EndsWith(@"\"))
             {
                 path += @"\";
             }
             path+="補藍鯨卡.sql";    //擷取指令碼位置
             if (File.Exists(path))
             {
                 FileInfo file = new FileInfo(path);
                 string script = file.OpenText().ReadToEnd();
                 script=script.Replace("H00001", CardNo);  //替換指令碼裡的參數
                 try
                 {
                       //執行指令碼
                    SqlConnection conn = new SqlConnection(connectonstring);
                    Microsoft.SqlServer.Management.Smo.Server server = new Server(new ServerConnection(conn));
                    int i= server.ConnectionContext.ExecuteNonQuery(script);
                    if (i == 1)
                    {
                        MessageBox.Show("恭喜!\n"+CardNo+" 補卡成功!","成功");
                        txtCardNo.Text = "";
                        CreateLog(CardNo, true);
                    }
                    else
                    {
                        MessageBox.Show("@_@ 再試一次吧!","失敗");
                    }
                     
                 }
                 catch (Exception es)
                 {
                     MessageBox.Show(es.Message);
                     CreateLog(CardNo + "  " + es.Message, false);
                 }
             }
             else
             {
                 MessageBox.Show("指令碼不存在!");
                 return;
             }
         }

OK,搞定了,看是很簡單吧~~

著意耕耘,自有收穫

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.