SQL Server CLR全功略之二---CLR存储过程
作者 佚名技术
来源 数据库编程
浏览
发布时间 2012-03-22
); } //填充结束,返回结果集 SqlContext.Pipe.SendResultsEnd(); } 其中6与7的不同在于:6返回5个结果集,其中每个结果集只有一条数据。7返回一个结果集,里面有5条数据。 最后说一下CLR存储过程的部署: Create proc 存储过程名 as EXTERNAL NAME 数据库中Assembly名称.程序集中Assembly名称.程序方法名。 注意,如果你的程序中有命名空间的话,要这样写: Create proc 存储过程名 as EXTERNAL NAME 数据库中Assembly名称.“程序命名空间.程序集中Assembly名称”.程序方法名。 下面的SQL是创建CLR程序集和CLR存储过程的SQL语句,假设我们编译好的dll位于C:\CLRDemo.dll,我们的程序没有命名空间(默认情况下,新建的SQL工程都没有命名空间,请注意) use pubs go create assembly CLRDemoAssemly from ''c:\CLRDemo.dll'' go create proc USP_SayHello as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.USP_SayHello go create proc USP_SayHelloByParameter (@Msg nvarchar(128)) as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.USP_SayHelloByParameter go create proc USP_SayHelloByReturn (@Msg nvarchar(128)) as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.USP_SayHelloByReturn go create proc USP_ExecuteBySqlCommand (@Id nvarchar(4),@Name nvarchar(32)) as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.USP_ExecuteBySqlCommand go create proc USP_ExecuteByExecuteAndSend (@Id nvarchar(4),@Name nvarchar(32)) as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.USP_ExecuteByExecuteAndSend go create proc UPS_PipeSendSqlDataRecord as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.UPS_PipeSendSqlDataRecord go create proc UPS_PipeSendResultSqlDataRecord as EXTERNAL NAME CLRDemoAssemly.StoredProcedures.UPS_PipeSendResultSqlDataRecord go 调用方式: exec USP_SayHello go exec USP_SayHelloByParameter ''Hello,TJVictor again'' go declare @Result int exec @Result=USP_SayHelloByReturn ''Hello,TJVictor again'' select @Result go exec USP_ExecuteBySqlCommand ''1234'',''Test USP_ExecuteBySqlCommand'' go exec USP_ExecuteByExecuteAndSend ''5678'',''Test USP_ExecuteByExecuteAndSend'' go exec UPS_PipeSendSqlDataRecord go exec UPS_PipeSendResultSqlDataRecord go 删除方式:注意删除Assembly时,一定要先把引用此Assembly的所有东西删除。 drop proc USP_SayHello drop proc USP_SayHelloByParameter drop proc USP_SayHelloByReturn drop proc USP_ExecuteBySqlCommand drop proc USP_ExecuteByExecuteAndSend drop proc UPS_PipeSendSqlDataRecord drop proc UPS_PipeSendResultSqlDataRecord go drop assembly CLRDemoAssemly 下面附带完整程序源代码 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于SQL Server CLR全功略之二---CLR存储过程的所有评论