日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
經(jīng)典講解創(chuàng)建CLR存儲過程

本文敘述了創(chuàng)建CLR存儲過程,從理論到實踐,筆者把代碼做了清晰地解釋,能保證你能明白,希望通過此文能給你帶來幫助。

創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的木壘哈薩克網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

首先,打開Visual Studio,點擊“創(chuàng)建”->“Visual C# ”->“數(shù)據(jù)庫”->“SQL Server 項目”。選擇完成后,會自動彈出一個數(shù)據(jù)庫連接的窗口,按照你的實際情況選擇吧,這里沒什么不同,就不多說了。按照這個步驟就可以創(chuàng)建一個新的SQL Server項目。

其次,右擊項目名稱,點擊“添加”->“CLR存儲過程”,這時會項目里會多出一個.cs文件。編輯一下。

 
 
 
  1. using System;  
  2. using System.Data;  
  3. using System.Data.SqlClient;  
  4. using System.Data.SqlTypes;  
  5. using Microsoft.SqlServer.Server;  
  6. public partial class Test  
  7. {  
  8.     [Microsoft.SqlServer.Server.SqlProcedure]  
  9.     public static void StoredProcedures()  
  10.     {  
  11.         // 在此處放置代碼  
  12.         SqlPipe sp = SqlContext.Pipe;  
  13.         string sql = "Select * from [Table_1]";  
  14.         using (SqlConnection conn = new SqlConnection
  15. ("context connection=true"))  
  16.         {  
  17.             conn.Open();  
  18.             SqlCommand cmd = new SqlCommand();  
  19.             cmd.CommandType = CommandType.Text;  
  20.             cmd.Connection = conn;  
  21.             cmd.CommandText = sql;  
  22.             SqlDataReader rdr = cmd.ExecuteReader();  
  23.             sp.Send(rdr);  
  24.             conn.Close();  
  25.         }  
  26.     }  
  27. };  

第16行:using (SqlConnection conn = new SqlConnection("context connection=true")) 是指“上下文連接”可以讓你使用當(dāng)前登錄到數(shù)據(jù)庫的用戶作為你的登錄數(shù)據(jù)庫的驗證信息。

編輯完成后,我們可以編譯一下,如果編譯通過。我們就可以將其部署到SQL Server上了。右擊項目名稱,選擇“部署”就OK了。當(dāng)然直接“運行”,系統(tǒng)也會自動部署它的。

這個時候,如果我們在SQL Server中執(zhí)行我們的CLR存儲過程,恐怕它會提示有錯誤?!敖乖?.NET Framework 中執(zhí)行用戶代碼。啟用 "clr enabled" 配置選項。
”這個時候,我們需要執(zhí)行下面這段腳本

 
 
 
  1. --在Sql Server中執(zhí)行這段代碼可以開啟CLR  
  2. exec sp_configure 'show advanced options', '1';  
  3. go  
  4. reconfigure;  
  5. go  
  6. exec sp_configure 'clr enabled', '1'  
  7. go  
  8. reconfigure;  
  9. exec sp_configure 'show advanced options', '1';  
  10. go   

現(xiàn)在好了。再次執(zhí)行CLR存儲過程“Exec StoredProcedures”。就完成了。

Transact-SQL 存儲過程與CLR存儲過程,基本上沒有什么不同,不過CLR存儲過程是不能在SQL Server里被“修改”的,選擇“Create”、“Alter”等也都是看不到存儲過程內(nèi)部的。真正的內(nèi)容只能在“SQL Server 項目”中才能看得到。

性能上,我之前試了100000條的數(shù)據(jù),同樣都是“Select * From 【Table】”Transact-SQL 存儲過程用了大約8秒鐘,而CLR存儲過程用了大約9~10秒鐘,所以肯定還是Transact-SQL 存儲過程會比CLR存儲過程稍快些。

有人說Transact-SQL 存儲過程沒有CLR存儲過程簡便、容易修改,暫時本人卻還沒有看出什么端倪,等待日后發(fā)掘。


分享題目:經(jīng)典講解創(chuàng)建CLR存儲過程
分享路徑:http://www.dlmjj.cn/article/dhpoodp.html