共用方式為


範例:指定 ID 和 IDREFS 指示詞

元素屬性可以指定為 ID 類型屬性,然後可以使用 IDREFS 屬性來參考它。這會啟用內部文件連結,而且與關聯式資料庫中的主索引鍵及外部索引鍵關聯性類似。

此範例說明如何使用 ID 及 IDREFS 指示詞,建立 ID 及 IDREFS 類型的屬性。因為 ID 不能是整數值,所以此範例中的 ID 值會經過轉換。換句話說,會經過類型轉換。ID 值會使用前置詞。

假設您想要建構如下所示的 XML:

<Customer CustomerID="C1" SalesOrderIDList=" O11 O22 O33..." >
    <SalesOrder SalesOrderID="O11" OrderDate="..." />
    <SalesOrder SalesOrderID="O22" OrderDate="..." />
    <SalesOrder SalesOrderID="O33" OrderDate="..." />
    ...
</Customer>

< Customer > 元素的 SalesOrderIDList 屬性是多重值屬性,會參考到 < SalesOrder > 元素的 SalesOrderID 屬性。若要建立此連結,SalesOrderID 屬性必須宣告為 ID 類型,而且 <Customer> 元素的 SalesOrderIDList 屬性必須宣告為 IDREFS 類型。因為一位客戶可以下多份訂單,所以要使用 IDREFS 類型。

IDREFS 類型的元素也會有一個以上的值。因此,您必須使用個別的 select 子句,以重複使用相同的標記、父系及索引鍵資料行資訊。然後 ORDER BY 必須確定構成 IDREFS 值的資料列順序,在它們的父成員下會分在同一組。

以下查詢會產生您想要的 XML。此查詢會使用 ID 和 IDREFS 指示詞來複寫資料行名稱 (SalesOrder!2!SalesOrderID!ID、Customer!1!SalesOrderIDList!IDREFS) 中的類型。

USE AdventureWorks2008R2;
GO
SELECT  1 as Tag,
        0 as Parent,
        C.CustomerID       [Customer!1!CustomerID],
        NULL               [Customer!1!SalesOrderIDList!IDREFS],
        NULL               [SalesOrder!2!SalesOrderID!ID],
        NULL               [SalesOrder!2!OrderDate]
FROM   Sales.Customer C 
UNION ALL 
SELECT  1 as Tag,
        0 as Parent,
        C.CustomerID,
        'O-'+CAST(SalesOrderID as varchar(10)), 
        NULL,
        NULL
FROM   Sales.Customer AS C
INNER JOIN Sales.SalesOrderHeader AS SOH
    ON  C.CustomerID = SOH.CustomerID
UNION ALL
SELECT 2 as Tag,
       1 as Parent,
        C.CustomerID,
        NULL,
        'O-'+CAST(SalesOrderID as varchar(10)),
        OrderDate
FROM   Sales.Customer AS C
INNER JOIN Sales.SalesOrderHeader AS SOH
    ON  C.CustomerID = SOH.CustomerIDORDER BY [Customer!1!CustomerID] ,
         [SalesOrder!2!SalesOrderID!ID],
         [Customer!1!SalesOrderIDList!IDREFS]
FOR XML EXPLICIT;

請參閱

參考