日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQL Server 2005中创建CLR存储过程

發布時間:2025/7/25 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL Server 2005中创建CLR存储过程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在2005之前的版本創建存儲過程都是在數據庫里面寫Transact-SQL語言實現的,不過現在SQL Server 2005支持用其他面向對象的語言編寫CLR存儲過程了,關于這樣做的好處,官方有很多解釋了,這里就直接說明實現方法了。
假設服務器里面有個test數據庫,數據庫有個架構user,還有一個表test1,然后有個sql登陸用戶叫test_user,將這個用戶設置成VS2005里面數據庫連接的登陸用戶。
在VS2005中創建一個項目,類別是SQL Server數據庫項目,然后往項目里面添加一個存儲過程。接著在該文件里面編寫如下存儲過程代碼:

using System; using System.Data.SqlClient; using System.Data.SqlTypes; using Microsoft.SqlServer.Server;public partial class StoredProcedures {[Microsoft.SqlServer.Server.SqlProcedure]public static void SelectAll(int qty){using (SqlConnection connection = new SqlConnection("context connection=true")){connection.Open();SqlCommand command = new SqlCommand(string.Format("Select top {0} * From Account ",qty), connection);SqlContext.Pipe.ExecuteAndSend(command);}} };


將上面代碼保存,命名為testProcedure.cs文件。接著有2中方法想數據庫里面添加這個存儲過程。
1. 打開.NET的命令行工具,然后將testProcedure.cs編譯成dll程序集testProcedure.dll

csc /t:library /out:testProcedure.dll testProcedure.cs
接著打開數據庫test,在數據庫里面的程序集右鍵菜單中點擊“添加新的程序集”項,然后瀏覽剛剛編譯好的testProcedure.dll程序集。
這樣就添加了這個程序集,接著新建sql查詢,在里面創建一個存儲過程如下:
CREATE PROCEDURE [user].SelectAll
AS EXTERNAL NAME testProcedure.StoredProcedures.SelectAll
GO
執行上面的查詢語句后,就在數據庫中成功添加了一個CLR存儲過程。注意上面的測試存儲過程是沒有參數的,
如果有的話,那么數據庫中的存儲過程原型必須和CLR語言中的原型一樣。
推薦使用這個方法創建CLRC存儲過程。
2. 使用VS來自動為sql創建存儲過程。 編寫一個調試腳本添加到項目里面,腳本可以只是簡單執行編好的
存儲過程。然后將上面的項目編譯并生成然后部署即可,還可以啟動調試來完成。VS會自動為數據庫添加相應的存儲過程。
不過第一種方法更加靈活和可靠。
另外使用第2種方法如果出現 錯誤:用戶未能執行存儲過程 sp_enable_sql_debug

這可能是由于:

  • 連接問題。需要有一個到服務器的穩定連接。

  • 在服務器上缺少必要的權限。若要在 SQL Server 2005 上調試,運行 Visual Studio 的帳戶和用于連接 SQL Server 的帳戶都必須是 sysadmin 角色的成員。用于連接 SQL Server 的帳戶要么是 Windows 用戶帳戶(如果您正在使用 Windows 身份驗證),要么是具有用戶 ID 和密碼的帳戶(如果您使用 SQL 身份驗證)。

也就是說那個test_user必須是sysadmin角色才行。

以上就是創建CLR存儲過程的全部內容。


在SQL Server 2005 中使用.net程序集的一項注意

在使用CLR存儲過程中遇到的一些問題,在這里進行記錄:
打開CLR的支持

--在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?

如果需要訪問外部資源的話,會有打開TRUSTWORTHY 屬性的提示

--打開數據庫的TRUSTWORTHY?屬性
ALTER?DATABASE?DB_Name?set?TRUSTWORTHY?on;

通過上述的設置,應該能輕易地加入程序集了
這個可以用鼠標完成就不貼代碼了

最后,手動添加存儲過程

--添加存儲過程
CREATE?PROCEDURE?[dbo].[存儲過程名稱]
????
@from?[nvarchar](50),?--?參數列表
????@to?[nvarchar](50)
WITH?EXECUTE?AS?CALLER
AS
EXTERNAL?NAME?
[程序集的名稱].[類名稱].[方法名稱]

轉載于:https://www.cnblogs.com/kevin-wang/archive/2010/09/29/1838398.html

總結

以上是生活随笔為你收集整理的SQL Server 2005中创建CLR存储过程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。