範例:指定 ID 與 IDREFS 指示詞

適用於:SQL ServerAzure SQL DatabaseAzure SQL 受控執行個體

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

此範例說明如何使用 IDIDREFS 指示詞,建立 IDIDREFS 類型的屬性。 因為 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。 此查詢會使用 IDIDREFS 指示詞來複寫資料行名稱 (SalesOrder!2!SalesOrderID!IDCustomer!1!SalesOrderIDList!IDREFS) 中的類型。

USE AdventureWorks2022;
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.CustomerID
ORDER BY [Customer!1!CustomerID] ,
         [SalesOrder!2!SalesOrderID!ID],
         [Customer!1!SalesOrderIDList!IDREFS]
FOR XML EXPLICIT;

另請參閱