在SQL Server 2005中创建CLR存储过程的详细介绍

 更新时间:2013年06月11日 11:53:51   作者:  
本篇文章是对在SQL Server 2005中创建CLR存储过程进行了详细的分析介绍,需要的朋友参考下

在2005之前的版本创建存储过程都是在数据库里面写Transact-SQL语言实现的,不过现在SQL Server 2005支持用其他面向对象的语言编写CLR存储过程了,关于这样做的好处,官方有很多解释了,这里就直接说明实现方法了。

假设服务器里面有个test数据库,数据库有个架构user,还有一个表test1,然后有个sql登陆用户叫test_user,将这个用户设置成VS2005里面数据库连接的登陆用户。

在VS2005中创建一个项目,类别是SQL Server数据库项目,然后往项目里面添加一个存储过程。接着在该文件里面编写如下存储过程代码:

复制代码 代码如下:

using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
public partial class StoredProcedures
{
    [Microsoft.SqlServer.Server.SqlProcedure]
    public static void SelectAll()
    {
        using (SqlConnection connection = new SqlConnection("context connection=true"))
        {
            connection.Open();
            SqlCommand command = new SqlCommand("SELECT * FROM [user].test1", connection);

            SqlContext.Pipe.ExecuteAndSend(command);
        }
    }
};


将上面代码保存,命名为testProcedure.cs文件。接着有2中方法想数据库里面添加这个存储过程。
1. 打开.NET的命令行工具,然后将testProcedure.cs编译成dll程序集testProcedure.dll
csc /t:library /out:testProcedure.dll testProcedure.cs 接着打开数据库test,在数据库里面的程序集右键菜单中点击“添加新的程序集”项,然后浏览刚刚编译好的testProcedure.dll程序集。这样就添加了这个程序集,接着新建sql查询,在里面创建一个存储过程如下:CREATE PROCEDURE [user].SelectAllAS EXTERNAL NAME testProcedure.StoredProcedures.SelectAllGO执行上面的查询语句后,就在数据库中成功添加了一个CLR存储过程。
注意上面的测试存储过程是没有参数的,如果有的话,那么数据库中的存储过程原型必须和CLR语言中的原型一样。推荐使用这个方法创建CLRC存储过程。

2. 使用VS来自动为sql创建存储过程。 编写一个调试脚本添加到项目里面,脚本可以只是简单执行编好的存储过程。然后将上面的项目编译并生成然后部署即可,还可以启动调试来完成。VS会自动为数据库添加相应的存储过程。不过第一种方法更加灵活和可靠。另外使用第2种方法如果出现 错误:用户未能执行存储过程 sp_enable_sql_debug这可能是由于:

•连接问题。需要有一个到服务器的稳定连接。

•在服务器上缺少必要的权限。若要在 SQL Server 2005 上调试,运行 Visual Studio 的帐户和用于连接 SQL Server 的帐户都必须是 sysadmin 角色的成员。用于连接 SQL Server 的帐户要么是 Windows 用户帐户(如果您正在使用 Windows 身份验证),要么是具有用户 ID 和密码的帐户(如果您使用 SQL 身份验证)。

也就是说那个test_user必须是sysadmin角色才行。以上就是创建CLR存储过程的全部内容。

相关文章

  • sql时间段切分实现每隔x分钟出一份高速门架车流量

    sql时间段切分实现每隔x分钟出一份高速门架车流量

    本文主要介绍了sql时间段切分实现每隔x分钟出一份高速门架车流量,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • SQL Server修改数据的几种语句详解

    SQL Server修改数据的几种语句详解

    在SQL中的基本操作就是增删改查,查询语句不会对数据库中的数据进行修改,下面这篇文章主要给大家介绍了关于SQL Server修改数据的几种语句,需要的朋友可以参考下
    2022-10-10
  • 浅析SQL语句中GROUP BY的用法

    浅析SQL语句中GROUP BY的用法

    “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理。
    2014-08-08
  • sql 服务器知识

    sql 服务器知识

    服务器组只是个逻辑上的概念,类似于班级或者QQ里面的同事、朋友、家人的分组。一般班级下面有N个学生。学生就相当于服务器了。
    2009-10-10
  • 详解SQL中Group By的用法

    详解SQL中Group By的用法

    GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组,记下来通过本文给大家介绍SQL中Group By的用法,需要的朋友参考下吧
    2016-03-03
  • sql server deadlock跟踪的4种实现方法

    sql server deadlock跟踪的4种实现方法

    一提到跟踪俩字,很多人想到警匪片中的场景,但这里介绍的可不是一样的哦,下面这篇文章主要给大家介绍了关于sql server deadlock跟踪的4种实现方法,文中通过图文以及示例代码介绍的非常详细,需要的朋友可以参考下
    2018-09-09
  • VS2015安装之后加装Sql server2014详细步骤

    VS2015安装之后加装Sql server2014详细步骤

    这篇文章主要介绍了VS2015安装之后加装SQL SERVER2014详细步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • SQLSERVER 创建索引实现代码

    SQLSERVER 创建索引实现代码

    是SQL Server编排数据的内部方法。它为SQL Server提供一种方法来编排查询数据
    2012-04-04
  • 必须会的SQL语句(六) 数据查询

    必须会的SQL语句(六) 数据查询

    这篇文章主要介绍了sqlserver中数据查询方法,需要的朋友可以参考下
    2015-01-01
  • SQL Server 更改DB的Collation

    SQL Server 更改DB的Collation

    经常发现同事爲了更改DB的Collation而删掉DB,重新创建过。其实,只要一条SQL就可以解,唔使哽麻烦!!
    2009-05-05

最新评论