濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 在SQL Server 2005中創(chuàng)建CLR存儲(chǔ)過程的詳細(xì)介紹

在SQL Server 2005中創(chuàng)建CLR存儲(chǔ)過程的詳細(xì)介紹

熱門標(biāo)簽:電銷外呼系統(tǒng)軟件功能 榕城市地圖標(biāo)注 北京400電話辦理多少錢 浙江穩(wěn)定外呼系統(tǒng)供應(yīng)商 慶陽地圖標(biāo)注 怎么給高德做地圖標(biāo)注 美團(tuán)地圖標(biāo)注商戶認(rèn)證注冊(cè) 咸陽電腦外呼系統(tǒng)運(yùn)營商 承德地圖標(biāo)注公司名需要花錢嗎

在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ǔ)過程代碼:

復(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ù)庫里面添加這個(gè)存儲(chǔ)過程。
1. 打開.NET的命令行工具,然后將testProcedure.cs編譯成dll程序集testProcedure.dll
csc /t:library /out:testProcedure.dll testProcedure.cs 接著打開數(shù)據(jù)庫test,在數(shù)據(jù)庫里面的程序集右鍵菜單中點(diǎn)擊“添加新的程序集”項(xiàng),然后瀏覽剛剛編譯好的testProcedure.dll程序集。這樣就添加了這個(gè)程序集,接著新建sql查詢,在里面創(chuàng)建一個(gè)存儲(chǔ)過程如下:CREATE PROCEDURE [user].SelectAllAS EXTERNAL NAME testProcedure.StoredProcedures.SelectAllGO執(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)目里面,腳本可以只是簡單執(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)證)。

也就是說那個(gè)test_user必須是sysadmin角色才行。以上就是創(chuàng)建CLR存儲(chǔ)過程的全部內(nèi)容。

您可能感興趣的文章:
  • SQL Server創(chuàng)建鏈接服務(wù)器的存儲(chǔ)過程示例分享
  • SQL Server 2005 創(chuàng)建簡單的存儲(chǔ)過程--總結(jié)分析
  • sqlserver2008查看表記錄或者修改存儲(chǔ)過程出現(xiàn)目錄名無效錯(cuò)誤解決方法
  • sqlserver 批量刪除存儲(chǔ)過程和批量修改存儲(chǔ)過程的語句
  • SQLServer存儲(chǔ)過程創(chuàng)建和修改的實(shí)現(xiàn)代碼

標(biāo)簽:江蘇 拉薩 貴州 昭通 重慶 新鄉(xiāng) 上海 呼和浩特

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在SQL Server 2005中創(chuàng)建CLR存儲(chǔ)過程的詳細(xì)介紹》,本文關(guān)鍵詞  在,SQL,Server,2005,中,創(chuàng)建,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在SQL Server 2005中創(chuàng)建CLR存儲(chǔ)過程的詳細(xì)介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于在SQL Server 2005中創(chuàng)建CLR存儲(chǔ)過程的詳細(xì)介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    蒙山县| 西宁市| 阜康市| 三穗县| 宜城市| 武功县| 彭山县| 象山县| 连江县| 安康市| 瓮安县| 徐汇区| 淳安县| 阳曲县| 拜泉县| 衡水市| 平塘县| 凤台县| 西昌市| 永修县| 腾冲县| 巴林左旗| 满洲里市| 林口县| 大方县| 城固县| 孟村| 丹巴县| 临沭县| 张家川| 沙坪坝区| 广州市| 宁晋县| 大连市| 正镶白旗| 五常市| 陇南市| 隆德县| 通山县| 南城县| 梨树县|