十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
今天给大家介绍一下创建CLR存储过程是怎样的。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。
为湘阴等地区用户提供了全套网页设计制作服务,及湘阴网站建设行业解决方案。主营业务为网站设计制作、成都做网站、湘阴网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
下面叙述了创建CLR存储过程,从理论到实践,笔者把代码做了清晰地解释,能保证你能明白,希望通过此文能给你带来帮助。
首先,打开Visual Studio,点击“创建”->“Visual C# ”->“数据库”->“SQL Server 项目”。选择完成后,会自动弹出一个数据库连接的窗口,按照你的实际情况选择吧,这里没什么不同,就不多说了。按照这个步骤就可以创建一个新的SQL Server项目。
其次,右击项目名称,点击“添加”->“CLR存储过程”,这时会项目里会多出一个.cs文件。编辑一下。
using System; using System.Data; using System.Data.SqlClient; using System.Data.SqlTypes; using Microsoft.SqlServer.Server; public partial class Test { [Microsoft.SqlServer.Server.SqlProcedure] public static void StoredProcedures() { // 在此处放置代码 SqlPipe sp = SqlContext.Pipe; string sql = "Select * from [Table_1]"; using (SqlConnection conn = new SqlConnection("context connection=true")) { conn.Open(); SqlCommand cmd = new SqlCommand(); cmd.CommandType = CommandType.Text; cmd.Connection = conn; cmd.CommandText = sql; SqlDataReader rdr = cmd.ExecuteReader(); sp.Send(rdr); conn.Close(); } } };
第16行:using (SqlConnection conn = new SqlConnection("context connection=true")) 是指“上下文连接”可以让你使用当前登录到数据库的用户作为你的登录数据库的验证信息。
编辑完成后,我们可以编译一下,如果编译通过。我们就可以将其部署到SQL Server上了。右击项目名称,选择“部署”就OK了。当然直接“运行”,系统也会自动部署它的。
这个时候,如果我们在SQL Server中执行我们的CLR存储过程,恐怕它会提示有错误。“禁止在 .NET Framework 中执行用户代码。启用 "clr enabled" 配置选项。
”这个时候,我们需要执行下面这段脚本
--在Sql Server中执行这段代码可以开启CLR exec sp_configure 'show advanced options', '1'; go reconfigure; go exec sp_configure 'clr enabled', '1' go reconfigure; exec sp_configure 'show advanced options', '1'; 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存储过程稍快些。
以上就是创建CLR存储过程是怎样的的全部内容了,更多与创建CLR存储过程是怎样的相关的内容可以搜索创新互联之前的文章或者浏览下面的文章进行学习哈!相信小编会给大家增添更多知识,希望大家能够支持一下创新互联!