最后說一下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