溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SQL Server中怎么創(chuàng)建CLR存儲過程

發(fā)布時間:2021-08-05 14:54:14 來源:億速云 閱讀:109 作者:Leah 欄目:數(shù)據(jù)庫

這篇文章將為大家詳細講解有關(guān)SQL Server中怎么創(chuàng)建CLR存儲過程,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

在2005之前的版本創(chuàng)建存儲過程都是在數(shù)據(jù)庫里面寫Transact-SQL語言實現(xiàn)的,不過現(xiàn)在SQL Server 2005支持用其他面向?qū)ο蟮恼Z言編寫CLR存儲過程了,關(guān)于這樣做的好處,官方有很多解釋了,這里就直接說明實現(xiàn)方法了。假設(shè)服務(wù)器里面有個test數(shù)據(jù)庫,數(shù)據(jù)庫有個架構(gòu)user,還有一個表test1,然后有個sql登陸用戶叫test_user,將這個用戶設(shè)置成VS2005里面數(shù)據(jù)庫連接的登陸用戶。在VS2005中創(chuàng)建一個項目,類別是SQL Server數(shù)據(jù)庫項目,然后往項目里面添加一個存儲過程。接著在該文件里面編寫如下存儲過程代碼:復(fù)制代碼 代碼如下: 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中方法想數(shù)據(jù)庫里面添加這個存儲過程。

1. 打開.NET的命令行工具,然后將testProcedure.cs編譯成dll程序集testProcedure.dllcsc /t:library /out:testProcedure.dll testProcedure.cs 接著打開數(shù)據(jù)庫test,在數(shù)據(jù)庫里面的程序集右鍵菜單中點擊“添加新的程序集”項,然后瀏覽剛剛編譯好的testProcedure.dll程序集。這樣就添加了這個程序集,接著新建sql查詢,在里面創(chuàng)建一個存儲過程如下:CREATE PROCEDURE [user].SelectAllAS EXTERNAL NAME testProcedure.StoredProcedures.SelectAllGO執(zhí)行上面的查詢語句后,就在數(shù)據(jù)庫中成功添加了一個CLR存儲過程。注意上面的測試存儲過程是沒有參數(shù)的,如果有的話,那么數(shù)據(jù)庫中的存儲過程原型必須和CLR語言中的原型一樣。推薦使用這個方法創(chuàng)建CLRC存儲過程。

2. 使用VS來自動為sql創(chuàng)建存儲過程。 編寫一個調(diào)試腳本添加到項目里面,腳本可以只是簡單執(zhí)行編好的存儲過程。然后將上面的項目編譯并生成然后部署即可,還可以啟動調(diào)試來完成。VS會自動為數(shù)據(jù)庫添加相應(yīng)的存儲過程。不過第一種方法更加靈活和可靠。另外使用第2種方法如果出現(xiàn) 錯誤:用戶未能執(zhí)行存儲過程 sp_enable_sql_debug這可能是由于:

?連接問題。需要有一個到服務(wù)器的穩(wěn)定連接。

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

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

關(guān)于SQL Server中怎么創(chuàng)建CLR存儲過程就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI