成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

經典講解創建CLR存儲過程

開發 后端
Transact-SQL 存儲過程與CLR存儲過程,基本上沒有什么不同,不過CLR存儲過程是不能在SQL Server里被“修改”的,選擇“Create”、“Alter”等也都是看不到存儲過程內部的。

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

首先,打開Visual Studio,點擊“創建”->“Visual C# ”->“數據庫”->“SQL Server 項目”。選擇完成后,會自動彈出一個數據庫連接的窗口,按照你的實際情況選擇吧,這里沒什么不同,就不多說了。按照這個步驟就可以創建一個新的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")) 是指“上下文連接”可以讓你使用當前登錄到數據庫的用戶作為你的登錄數據庫的驗證信息。

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

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

  1. --在Sql Server中執行這段代碼可以開啟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   

現在好了。再次執行CLR存儲過程“Exec StoredProcedures”。就完成了。

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

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

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

【編輯推薦】

  1. 淺析基于SQL2005的CLR存儲過程
  2. 分析與對比CLR Via C#靜態構造函數的性能
  3. 為你解疑:CLR是什么?
  4. linq to sql多表查詢淺析
  5. linq to sql多表基礎描述
責任編輯:阡陌 來源: CSDN
相關推薦

2009-10-22 14:05:55

CLR存儲過程

2009-09-17 18:27:40

CLR是什么

2009-10-22 13:02:47

SQL CLR存儲過程

2009-09-18 14:09:57

SQL CLR存儲過程

2009-10-22 18:06:31

CLR存儲過程

2009-09-18 10:55:17

CLR存儲過程

2009-10-22 15:09:40

CLR存儲過程

2009-09-17 19:19:17

CLR存儲過程

2009-10-23 10:50:04

CLR安全性

2009-10-22 16:08:52

.NET CLR是什么

2010-07-05 10:06:51

SQL Server擴

2010-04-16 10:11:20

Oracle存儲過程

2010-10-09 17:08:15

MySQL存儲過程

2011-04-11 09:16:31

Sybase存儲

2010-11-29 15:25:39

Sybase存儲過程

2010-05-19 14:03:41

MySQL 存儲過程

2009-10-22 11:25:08

CLR函數壓縮

2010-05-27 17:17:37

Subversion入

2010-10-12 11:07:34

MySQL存儲過程

2010-06-07 15:36:36

MySQL存儲過程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 丁香综合 | 自拍偷拍第一页 | 国产欧美一区二区三区在线看 | 欧美日韩福利视频 | 成人av播放 | 国产一区二区 | 成人av高清在线观看 | 久久精品久久久 | 日韩av黄色 | 激情在线视频 | 国产高清久久久 | 91玖玖| 日韩av啪啪网站大全免费观看 | 嫩草视频在线免费观看 | 亚洲国产成人精品女人久久久野战 | 国产女人叫床高潮大片免费 | 久久男人| 国产香蕉视频 | 日本h片在线观看 | 欧美精品久久久 | 亚洲视频二区 | 国产精品1区2区3区 一区中文字幕 | 亚洲欧美中文日韩在线 | 久草在线| 国产成人高清 | 久久精品免费 | 日韩一区二区三区在线 | www.色.com| 一区二区在线看 | 色婷婷综合久久久中字幕精品久久 | 国产欧美精品一区二区色综合朱莉 | www久久| 精品欧美二区 | 日日碰狠狠躁久久躁婷婷 | 精品国产乱码久久久久久蜜柚 | 精品欧美一区二区三区久久久 | 情侣酒店偷拍一区二区在线播放 | 成人av播放 | 国产精品视频一二三区 | 日韩中文在线视频 | 午夜视频导航 |