在2005之前的版本創建存儲過程都是在數據庫裡面寫Transact-SQL語言實現的,不過現在SQL Server 2005支持用其他面向對象的語言編寫CLR存儲過程了,關於這樣做的好處,官方有很多解釋了,這裡就直接說明實現方法了。
假設服務器裡面有個test數據庫,數據庫有個架構user,還有一個表test1,然後有個sql登陸用戶叫test_user,將這個用戶設置成VS2005裡面數據庫連接的登陸用戶。
在VS2005中創建一個項目,類別是SQL Server數據庫項目,然後往項目裡面添加一個存儲過程。接著在該文件裡面編寫如下存儲過程代碼:
復制代碼 代碼如下:
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
public partial class StoredProcedures
{
[Microsoft.SqlServer.Server.SqlProcedure]
public static void SelectAll()
{
using (SqlConnection connection = new SqlConnection("context connection=true"))
{
connection.Open();
SqlCommand command = new SqlCommand("SELECT * FROM [user].test1", 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].SelectAllAS EXTERNAL NAME testProcedure.StoredProcedures.SelectAllGO執行上面的查詢語句後,就在數據庫中成功添加了一個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存儲過程的全部內容。