龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > C#开发 >

经典讲解创建CLR存储过程

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
本文叙述了创建CLR存储过程,从理论到实践,笔者把代码做了清晰地解释,能保证你能明白,希望通过此文能给你带来帮助。 首先,打开Visual Studio,点击“创建”->“Visual C# ”->“数据

本文叙述了创建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存储过程简便、容易修改,暂时本人却还没有看出什么端倪,等待日后发掘。。。。。。


精彩图集

赞助商链接