亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2013年06月11日 11:53:51   作者:  
本篇文章是對在SQL Server 2005中創(chuàng)建CLR存儲過程進行了詳細的分析介紹,需要的朋友參考下

在2005之前的版本創(chuàng)建存儲過程都是在數據庫里面寫Transact-SQL語言實現的,不過現在SQL Server 2005支持用其他面向對象的語言編寫CLR存儲過程了,關于這樣做的好處,官方有很多解釋了,這里就直接說明實現方法了。

假設服務器里面有個test數據庫,數據庫有個架構user,還有一個表test1,然后有個sql登陸用戶叫test_user,將這個用戶設置成VS2005里面數據庫連接的登陸用戶。

在VS2005中創(chuàng)建一個項目,類別是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查詢,在里面創(chuàng)建一個存儲過程如下:CREATE PROCEDURE [user].SelectAllAS EXTERNAL NAME testProcedure.StoredProcedures.SelectAllGO執(zhí)行上面的查詢語句后,就在數據庫中成功添加了一個CLR存儲過程。
注意上面的測試存儲過程是沒有參數的,如果有的話,那么數據庫中的存儲過程原型必須和CLR語言中的原型一樣。推薦使用這個方法創(chuàng)建CLRC存儲過程。

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

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

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

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

相關文章

  • sql時間段切分實現每隔x分鐘出一份高速門架車流量

    sql時間段切分實現每隔x分鐘出一份高速門架車流量

    本文主要介紹了sql時間段切分實現每隔x分鐘出一份高速門架車流量,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • SQL?Server修改數據的幾種語句詳解

    SQL?Server修改數據的幾種語句詳解

    在SQL中的基本操作就是增刪改查,查詢語句不會對數據庫中的數據進行修改,下面這篇文章主要給大家介紹了關于SQL?Server修改數據的幾種語句,需要的朋友可以參考下
    2022-10-10
  • 淺析SQL語句中GROUP BY的用法

    淺析SQL語句中GROUP BY的用法

    “Group By”從字面意義上理解就是根據“By”指定的規(guī)則對數據進行分組,所謂的分組就是將一個“數據集”劃分成若干個“小區(qū)域”,然后針對若干個“小區(qū)域”進行數據處理。
    2014-08-08
  • sql 服務器知識

    sql 服務器知識

    服務器組只是個邏輯上的概念,類似于班級或者QQ里面的同事、朋友、家人的分組。一般班級下面有N個學生。學生就相當于服務器了。
    2009-10-10
  • 詳解SQL中Group By的用法

    詳解SQL中Group By的用法

    GROUP BY 語句用于結合合計函數,根據一個或多個列對結果集進行分組,記下來通過本文給大家介紹SQL中Group By的用法,需要的朋友參考下吧
    2016-03-03
  • sql server deadlock跟蹤的4種實現方法

    sql server deadlock跟蹤的4種實現方法

    一提到跟蹤倆字,很多人想到警匪片中的場景,但這里介紹的可不是一樣的哦,下面這篇文章主要給大家介紹了關于sql server deadlock跟蹤的4種實現方法,文中通過圖文以及示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-09-09
  • VS2015安裝之后加裝Sql server2014詳細步驟

    VS2015安裝之后加裝Sql server2014詳細步驟

    這篇文章主要介紹了VS2015安裝之后加裝SQL SERVER2014詳細步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • SQLSERVER 創(chuàng)建索引實現代碼

    SQLSERVER 創(chuàng)建索引實現代碼

    是SQL Server編排數據的內部方法。它為SQL Server提供一種方法來編排查詢數據
    2012-04-04
  • 必須會的SQL語句(六) 數據查詢

    必須會的SQL語句(六) 數據查詢

    這篇文章主要介紹了sqlserver中數據查詢方法,需要的朋友可以參考下
    2015-01-01
  • SQL Server 更改DB的Collation

    SQL Server 更改DB的Collation

    經常發(fā)現同事爲了更改DB的Collation而刪掉DB,重新創(chuàng)建過。其實,只要一條SQL就可以解,唔使哽麻煩??!
    2009-05-05

最新評論