gate_s

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

 最近做一个项目,需要做一个SQL SERVER 2005的CLR的存储过程,研究了一下CLR的实现。为方便以后再使用,在这里总结一下我的实现流程,也供对CLR感兴趣但又不知道如何实现的朋友们做一下参考,如果有不同意见,望多指教。在这里先以实现CLR存储过程为例子来进行说明。

      1。首先,启用数据库的CLR功能

          sp_configure 'clr enabled', 1;
          GO
          RECONFIGURE;
          GO

       2。即然是要创建CLR存储过程,那么首先就得用C#(或者其它语言)编写一个类库实现存储过程要执行的逻辑。创建的这个类库可以有两种方法:一种是创建一个普通的C# Class library;另一个是用VS2008创建一个SQL Server Project,方法:New Project/Database Projects/Microsoft SQL Server/SQL CLR/SQL Server Project.

无论使用哪一种方法,最终都应满足下面这两个条件:

         (1)对于SQL Server 2005,所使用的.net程序集必须是.NET 2.0的。

         (2)要做为存储过程的方法,必须是static,public,且加有SqlProcedure附加属性。

        

1    [SqlProcedure]
2    public static void ExecSQLCLRProc(int messageID, int iVersion)
3    {
4   
5    }

 

在这里我使用的是用VS建一个SQL Server Project,因为它可以自动为我们实现以上这两个步骤。有了[SqlProcedure]这个属性,SQL Server就可以使用这个公开的方法创建存储过程了。

 

   3。建好CLR Project后,就需要将CLR实施到数据库了。

        可以用两种方法实施:

        (1):在VS2008中使用Deploy操作,就可以自动将建好的存储过实施到数据库。

        (2):在T-SQL里执行:

              CREATE ASSEMBLY FROM 'DLL Path' WITH PERMISSION_SET = SAFE|EXTERNAL_ACCESS|UNSAFE为DLL创建程序集。

              Create Proc NCIP_ParseMessage
                  params
              AS 
              EXTERNAL NAME methodpath

              依据程序集里公开的方法创建存储过程。

 

    重点说明的是,SQL Server对CLR程序集提供了三种访问权限级别:SAFE,EXTERNAL_ACCESS,UNSAFE。如果要实施的是SAFE的级别,那么直接使用上面的两种的方法中的任何一种就可以实施了。但是由于我在存储过程中要访问网络资源,所以要用EXTERNAL_ACCESS或UNSAFE的权限级别实现

   4。实现EXTERNAL_ACCESS权限级别的CLR存储过程。(不推荐使用UNSAFE)

        (1)对SQL CLR使用strong name.先用SN.exe生成一个SNK文件,右击项目-properties-Signing-选中Sign the assembly,选择生成的SNK文件。

        (2)在数据库里为DLL生成一个KEY。

             Use master
             CREATE ASYMMETRIC KEY SQLCLRKey FROM EXECUTABLE FILE = 'DLL Path'  
             CREATE LOGIN loginname FROM ASYMMETRIC KEY SQLCLRKey 
             GRANT EXTERNAL ACCESS ASSEMBLY TO loginname

       然后在再用 3 中的方法就可以实现。

  5。多个程序集相互引用。如果有多个程序集,并且之前存在引用的话,那么可能还需要做以下的操作:

       (1)在每个被引用的project的AssemblyInfo.cs加下面的代码:

1 using System.Security;
2 [assembly: AllowPartiallyTrustedCallers]

      (2)如果是用SQL Server Project,还要将项目属性/Assembly name 改为唯一的名字

      (3)为每一个别Project生成一个SNK文件,并创建相应的ASYMMETRIC KEY,LOGIN,授于LOGIN相应的访问权限。

posted on 2014-12-07 12:53  gate_s  阅读(469)  评论(0编辑  收藏  举报