Jegyzet
Az oldalhoz való hozzáférés engedélyezést igényel. Próbálhatod be jelentkezni vagy könyvtárat váltani.
Az oldalhoz való hozzáférés engedélyezést igényel. Megpróbálhatod a könyvtár váltását.
A következőkre vonatkozik:SQL Server
Visszaadja az olyan elemcsomópontok sorsorát, amelyek xs:ID értékei egyeznek az $arg-ben megadott xs:IDREF értékek egyikével vagy többével.
Szemantika
fn:id($arg as xs:IDREF*) as element()*
Arguments
$arg
Egy vagy több xs:IDREF érték.
Megjegyzések
A függvény eredménye egy olyan elemsorozat az XML példányban, dokumentumsorrendben, amelynek xs:ID értéke megegyezik egy vagy több xs:IDREF jelölt xs:IDREF listáján.
Ha az xs:IDREF érték nem egyezik egyetlen elemmel sem, a függvény az üres sorozatot adja vissza.
Példák
Ez a téma XQuery példákat kínál XML példányok ellen, amelyek különböző xml típusú oszlopokban tárolódnak az AdventureWorks2025 adatbázisban.
A. Az IDREF attribútumérték alapján elemek lekérése
A következő példa az fn:id segítségével lekéri az <employee> elemeket az IDREF manager attribútumja alapján. Ebben a példában a manager attribútum IDREF típus, az eid attribútum pedig ID típusú attribútum.
Egy adott menedzser attribútumérték esetén az id() függvény megtalálja azt az <employee> elemet, amelynek ID típus attribútumértéke megegyezik a bemeneti IDREF értékkel. Más szóval, egy adott alkalmazott esetén az id() függvény visszaadja az alkalmazotti vezetőt.
A példában ez történik:
Egy XML sémagyűjtemény jön létre.
Egy típusozott xml változót az XML sémagyűjtemény használatával hoznak létre.
A lekérdezés visszakapja azt az elemet, amelynek azonosító attribútumértéke van, amelyet az elem menedzser IDREF attribútuma <
employee> hivatkoz.
-- If exists, drop the XML schema collection (SC).
-- drop xml schema collection SC
-- go
create xml schema collection SC as
'<schema xmlns="http://www.w3.org/2001/XMLSchema" xmlns:e="emp" targetNamespace="emp">
<element name="employees" type="e:EmployeesType"/>
<complexType name="EmployeesType">
<sequence>
<element name="employee" type="e:EmployeeType" minOccurs="0" maxOccurs="unbounded" />
</sequence>
</complexType>
<complexType name="EmployeeType">
<attribute name="eid" type="ID" />
<attribute name="name" type="string" />
<attribute name="manager" type="IDREF" />
</complexType>
</schema>'
go
declare @x xml(SC)
set @x='<e:employees xmlns:e="emp">
<employee eid="e1" name="Joe" manager="e10" />
<employee eid="e2" name="Bob" manager="e10" />
<employee eid="e10" name="Dave" manager="e10" />
</e:employees>'
select @x.value(' declare namespace e="emp";
(fn:id(e:employees/employee[@name="Joe"]/@manager)/@name)[1]', 'varchar(50)')
Go
A lekérdezés "Dave" értéket ad vissza. Ez arra utal, hogy Dave Joe menedzsere.
B. Elemek lekérése az OrderList IDREFS attribútumértéke alapján
A következő példában az elem OrderList attribútuma <Customer> IDREFS típusú attribútum. Felsorolja az adott ügyfél rendelési azonosítóit. Minden rendi azonosító esetén van egy <Order> elem gyermek a rendelő érték megadása alatt.<Customer>
A lekérdezési kifejezés, data(CustOrders:Customers/Customer[1]/@OrderList)[1], az első IDRES listából származó értéket kéri az első ügyfél számára. Ezt az értéket az id() függvénynek továbbítják. A függvény ezután megtalálja azt az <Order> elemet, amelynek OrderID attribútumértéke megegyezik az id() függvény bemenetével.
drop xml schema collection SC
go
create xml schema collection SC as
'<schema xmlns="http://www.w3.org/2001/XMLSchema" xmlns:Customers="Customers" targetNamespace="Customers">
<element name="Customers" type="Customers:CustomersType"/>
<complexType name="CustomersType">
<sequence>
<element name="Customer" type="Customers:CustomerType" minOccurs="0" maxOccurs="unbounded" />
</sequence>
</complexType>
<complexType name="OrderType">
<sequence minOccurs="0" maxOccurs="unbounded">
<choice>
<element name="OrderValue" type="integer" minOccurs="0" maxOccurs="unbounded"/>
</choice>
</sequence>
<attribute name="OrderID" type="ID" />
</complexType>
<complexType name="CustomerType">
<sequence minOccurs="0" maxOccurs="unbounded">
<choice>
<element name="spouse" type="string" minOccurs="0" maxOccurs="unbounded"/>
<element name="Order" type="Customers:OrderType" minOccurs="0" maxOccurs="unbounded"/>
</choice>
</sequence>
<attribute name="CustomerID" type="string" />
<attribute name="OrderList" type="IDREFS" />
</complexType>
</schema>'
go
declare @x xml(SC)
set @x='<CustOrders:Customers xmlns:CustOrders="Customers">
<Customer CustomerID="C1" OrderList="OrderA OrderB" >
<spouse>Jenny</spouse>
<Order OrderID="OrderA"><OrderValue>11</OrderValue></Order>
<Order OrderID="OrderB"><OrderValue>22</OrderValue></Order>
</Customer>
<Customer CustomerID="C2" OrderList="OrderC OrderD" >
<spouse>John</spouse>
<Order OrderID="OrderC"><OrderValue>33</OrderValue></Order>
<Order OrderID="OrderD"><OrderValue>44</OrderValue></Order>
</Customer>
<Customer CustomerID="C3" OrderList="OrderE OrderF" >
<spouse>Jane</spouse>
<Order OrderID="OrderE"><OrderValue>55</OrderValue></Order>
<Order OrderID="OrderF"><OrderValue>55</OrderValue></Order>
</Customer>
<Customer CustomerID="C4" OrderList="OrderG" >
<spouse>Tim</spouse>
<Order OrderID="OrderG"><OrderValue>66</OrderValue></Order>
</Customer>
<Customer CustomerID="C5" >
</Customer>
<Customer CustomerID="C6" >
</Customer>
<Customer CustomerID="C7" >
</Customer>
</CustOrders:Customers>'
select @x.query('declare namespace CustOrders="Customers";
id(data(CustOrders:Customers/Customer[1]/@OrderList)[1])')
-- result
<Order OrderID="OrderA">
<OrderValue>11</OrderValue>
</Order>
Megvalósítási korlátozások
Ezek a korlátozások:
Az SQL Server nem támogatja az id() kétargumentusú verzióját.
Az SQL Server megköveteli, hogy az id() argumentumtípusa az xs:IDREF* altípusa legyen.