为了账号安全,请及时绑定邮箱和手机立即绑定

简单创建与布署CLR存储过程

标签:
SQL Server

今天的博文是学习CLR存储过程,一个简单的例子,学会怎样创建,编译,布署在SQL中。CLR能做一些T-SQL无法做的事情,很多情况之后,它比T-SQL快。

打开VS2013,创建一个新专案,参考下面5个步骤:

 

如果你想写好的CLR存储过程布署在SQL2008上,上面标记2选择.NET Framework3.5。

创建一个新item:



创建一个存储过程的类别:

 

点击标记12的铵钮之后,在VS中将产生一个空白的存储过程类别:

 

接下来,我们就可以在标记13处写存储过程了。




下面是可复制代码:

SqlConnection connection = new SqlConnection("context connection=true");connection.Open();string sql = "SELECT [Fruit_nbr],[FruitKind_nbr], [FruitName] FROM [dbo].[Fruit]";SqlCommand command = new SqlCommand(sql, connection);SqlDataReader reader = command.ExecuteReader();SqlContext.Pipe.Send(reader);

View Code


BUILD Soluton:



Build成功,可以看到output信息:

下面是对SQL的操作,打开Microsoft SQL Server Management Studio 2014,找到对应的数据库,然后按标记1至标记4进行操作,标记3是按mouse右键才能显示标记4。

 
在Assembly对话窗口中,在标记1中,找到刚才编译好的DLL,然后点标记3"OK"铵钮即可。


在数据库的中,可看到添加好的Assembly:



OK,最后一个步骤布署,创建存储过程:

 

成功之后,我们会到一个带一把锁的存储过程:



大功告成!!!
运执行一下我们创建好的CLR存储过程EXECUTE [dbo].[GetFruitAll],它没有预期结果,出现一个异常:
Execution of user code in the .NET Framework is disabled. Enable "clr enabled" configuration option.



此时,我们需要

Enabling CLR Integration 

sp_configure 'clr enabled', 1GORECONFIGUREGO

View Code


再次执行CLR存储过程,得到我们想要的结果:

 

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消