SQL Server 2005中创建CLR存储过程
在2005之前的版本創(chuàng)建存儲(chǔ)過程都是在數(shù)據(jù)庫里面寫Transact-SQL語言實(shí)現(xiàn)的,不過現(xiàn)在SQL Server 2005支持用其他面向?qū)ο蟮恼Z言編寫CLR存儲(chǔ)過程了,關(guān)于這樣做的好處,官方有很多解釋了,這里就直接說明實(shí)現(xiàn)方法了。
假設(shè)服務(wù)器里面有個(gè)test數(shù)據(jù)庫,數(shù)據(jù)庫有個(gè)架構(gòu)user,還有一個(gè)表test1,然后有個(gè)sql登陸用戶叫test_user,將這個(gè)用戶設(shè)置成VS2005里面數(shù)據(jù)庫連接的登陸用戶。
在VS2005中創(chuàng)建一個(gè)項(xiàng)目,類別是SQL Server數(shù)據(jù)庫項(xiàng)目,然后往項(xiàng)目里面添加一個(gè)存儲(chǔ)過程。接著在該文件里面編寫如下存儲(chǔ)過程代碼:
將上面代碼保存,命名為testProcedure.cs文件。接著有2中方法想數(shù)據(jù)庫里面添加這個(gè)存儲(chǔ)過程。
1. 打開.NET的命令行工具,然后將testProcedure.cs編譯成dll程序集testProcedure.dll
接著打開數(shù)據(jù)庫test,在數(shù)據(jù)庫里面的程序集右鍵菜單中點(diǎn)擊“添加新的程序集”項(xiàng),然后瀏覽剛剛編譯好的testProcedure.dll程序集。
這樣就添加了這個(gè)程序集,接著新建sql查詢,在里面創(chuàng)建一個(gè)存儲(chǔ)過程如下:
CREATE PROCEDURE [user].SelectAll
AS EXTERNAL NAME testProcedure.StoredProcedures.SelectAll
GO
執(zhí)行上面的查詢語句后,就在數(shù)據(jù)庫中成功添加了一個(gè)CLR存儲(chǔ)過程。注意上面的測(cè)試存儲(chǔ)過程是沒有參數(shù)的,
如果有的話,那么數(shù)據(jù)庫中的存儲(chǔ)過程原型必須和CLR語言中的原型一樣。
推薦使用這個(gè)方法創(chuàng)建CLRC存儲(chǔ)過程。
2. 使用VS來自動(dòng)為sql創(chuàng)建存儲(chǔ)過程。 編寫一個(gè)調(diào)試腳本添加到項(xiàng)目里面,腳本可以只是簡(jiǎn)單執(zhí)行編好的
存儲(chǔ)過程。然后將上面的項(xiàng)目編譯并生成然后部署即可,還可以啟動(dòng)調(diào)試來完成。VS會(huì)自動(dòng)為數(shù)據(jù)庫添加相應(yīng)的存儲(chǔ)過程。
不過第一種方法更加靈活和可靠。
另外使用第2種方法如果出現(xiàn) 錯(cuò)誤:用戶未能執(zhí)行存儲(chǔ)過程 sp_enable_sql_debug
這可能是由于:
-
連接問題。需要有一個(gè)到服務(wù)器的穩(wěn)定連接。
-
在服務(wù)器上缺少必要的權(quán)限。若要在 SQL Server 2005 上調(diào)試,運(yùn)行 Visual Studio 的帳戶和用于連接 SQL Server 的帳戶都必須是 sysadmin 角色的成員。用于連接 SQL Server 的帳戶要么是 Windows 用戶帳戶(如果您正在使用 Windows 身份驗(yàn)證),要么是具有用戶 ID 和密碼的帳戶(如果您使用 SQL 身份驗(yàn)證)。
以上就是創(chuàng)建CLR存儲(chǔ)過程的全部?jī)?nèi)容。
在SQL Server 2005 中使用.net程序集的一項(xiàng)注意
在使用CLR存儲(chǔ)過程中遇到的一些問題,在這里進(jìn)行記錄:
打開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?
如果需要訪問外部資源的話,會(huì)有打開TRUSTWORTHY 屬性的提示
--打開數(shù)據(jù)庫的TRUSTWORTHY?屬性ALTER?DATABASE?DB_Name?set?TRUSTWORTHY?on;
通過上述的設(shè)置,應(yīng)該能輕易地加入程序集了
這個(gè)可以用鼠標(biāo)完成就不貼代碼了
最后,手動(dòng)添加存儲(chǔ)過程
CREATE?PROCEDURE?[dbo].[存儲(chǔ)過程名稱]
????@from?[nvarchar](50),?--?參數(shù)列表
????@to?[nvarchar](50)
WITH?EXECUTE?AS?CALLER
AS
EXTERNAL?NAME?[程序集的名稱].[類名稱].[方法名稱]
轉(zhuǎn)載于:https://www.cnblogs.com/kevin-wang/archive/2010/09/29/1838398.html
總結(jié)
以上是生活随笔為你收集整理的SQL Server 2005中创建CLR存储过程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JBPM executionServic
- 下一篇: if test project can'