在SQL Server 2008中運用表值參數(TVP)(2)_Mssql數據庫教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:SQL Server數據庫增強版備份體驗
      老鳥說事:Microsoft SQL Server數據庫增強版備份體驗 在歐洲,有一首流傳很廣的民諺: 因為丟失一根鐵釘,我們失去了一塊馬蹄鐵; 因為失去一塊馬蹄鐵,我們失去了一匹駿馬; 因為失去

       除了簡單的查找源系統鍵的代理鍵之外,還有一種情況可利用表值參數,即事實表含有一個不存在于維度表的源系統鍵。在這種情況下,我們則想要在維度里創建一個推斷成員(Inferred member),也就是說,創建一個新的代理鍵并把它添加到維度里,在我們從源系統里獲得真正的維度行之后再把它替換更新掉。

        下面的演示編碼只在SQL Server 2008的二月份社區測試試用版中進行過測試。

        新建一個表類型

        為了把表作為一個參數傳遞到存儲過程或函數中,你首先要創建一個TABLE TYPE,如下所示:

      以下為引用的內容:
        CREATETYPESourceKeyListASTABLE(
        SourceKeyNVARCHAR(50)
        )
        GO

        T-SQL編碼跟新建一個普通的表的編碼非常相似。你可以查詢當前數據庫的sys.types來確定已創建的任何表類型:

      以下為引用的內容:
        SELECTname,system_type_id,user_type_id
        FROMsys.types
        WHEREis_table_type=1

        新建一個帶有表值參數的存儲過程

        我們要創建一個存儲過程,該存儲過程執行代理鍵查找命令,如果源鍵不存在則添加一個推理成員。首先我們需要新建一個維度表樣例:

      以下為引用的內容:
        CREATETABLEdbo.dim_Customer(
        sk_CustomerINTIDENTITYNOTNULL,
        CustomerSourceKeyNVARCHAR(50)NOTNULL,
        CustomerNameNVARCHAR(50)NOTNULL,
        InferredMemberBITNOTNULL
        )

        代理鍵是整數類型,我們使用IDENTITY屬性來自動分配插入行的序列號。當我們插入一行源鍵不存在的行時,InferredMember列設置為1。當我們在維度處理過程中從源系統中獲得該行后,它將替換掉推理成員行,而InferredMember列的值會變成0。

      分享:如何有效防止Java程序源碼被人偷窺?
      Java程序的源代碼很容易被別人偷看,只要有一個反編譯器,任何人都可以分析別人的代碼。本文討論如何在不修改原有程序的情況下,通過加密技術保護源代碼。 一、為什么要加密? 對于傳統的C或

      來源:模板無憂//所屬分類:Mssql數據庫教程/更新時間:2008-08-22
      相關Mssql數據庫教程