Jak psát dotazy se složitým filtrováním (LINQ to XML)
Někdy chcete psát dotazy LINQ to XML se složitými filtry. Můžete například najít všechny prvky, které mají podřízený prvek s konkrétním názvem a hodnotou. Tento článek poskytuje příklad zápisu dotazu se složitým filtrováním.
Příklad: Vyhledání s vnořeným dotazem v klauzuli Where
Tento příklad ukazuje, jak najít všechny PurchaseOrder
prvky, které mají:
- Podřízený
Address
prvek, jehožType
atribut se rovná "Shipping". - Podřízený
State
prvek, který se rovná "NY".
V klauzuli používá vnořený Where
dotaz a Any
operátor vrátí true
, pokud má kolekce nějaké prvky. Příklad používá ukázkový soubor XML dokumentu XML: Více nákupních objednávek.
Další informace o operátoru Any
najdete v tématu Operace kvantifikátoru (C#) a Operace kvantifikátoru (Visual Basic).
XElement root = XElement.Load("PurchaseOrders.xml");
IEnumerable<XElement> purchaseOrders =
from el in root.Elements("PurchaseOrder")
where
(from add in el.Elements("Address")
where
(string)add.Attribute("Type") == "Shipping" &&
(string)add.Element("State") == "NY"
select add)
.Any()
select el;
foreach (XElement el in purchaseOrders)
Console.WriteLine((string)el.Attribute("PurchaseOrderNumber"));
Dim root As XElement = XElement.Load("PurchaseOrders.xml")
Dim purchaseOrders As IEnumerable(Of XElement) = _
From el In root.<PurchaseOrder> _
Where _
(From add In el.<Address> _
Where _
add.@Type = "Shipping" And _
add.<State>.Value = "NY" _
Select add) _
.Any() _
Select el
For Each el As XElement In purchaseOrders
Console.WriteLine(el.@PurchaseOrderNumber)
Next
Tento příklad vytvoří následující výstup:
99505
Příklad: Vyhledání v jazyce XML v oboru názvů
Následující příklad ukazuje stejný dotaz jako výše, ale pro XML, který je v oboru názvů. Další informace najdete v tématu Přehled oborů názvů.
Tento příklad používá ukázkový soubor XML dokumentu XML: Více nákupních objednávek v oboru názvů.
XElement root = XElement.Load("PurchaseOrdersInNamespace.xml");
XNamespace aw = "http://www.adventure-works.com";
IEnumerable<XElement> purchaseOrders =
from el in root.Elements(aw + "PurchaseOrder")
where
(from add in el.Elements(aw + "Address")
where
(string)add.Attribute(aw + "Type") == "Shipping" &&
(string)add.Element(aw + "State") == "NY"
select add)
.Any()
select el;
foreach (XElement el in purchaseOrders)
Console.WriteLine((string)el.Attribute(aw + "PurchaseOrderNumber"));
Imports <xmlns:aw='http://www.adventure-works.com'>
Module Module1
Sub Main()
Dim root As XElement = XElement.Load("PurchaseOrdersInNamespace.xml")
Dim purchaseOrders As IEnumerable(Of XElement) = _
From el In root.<aw:PurchaseOrder> _
Where _
(From add In el.<aw:Address> _
Where _
add.@aw:Type = "Shipping" And _
add.<aw:State>.Value = "NY" _
Select add) _
.Any() _
Select el
For Each el As XElement In purchaseOrders
Console.WriteLine(el.@aw:PurchaseOrderNumber)
Next
End Sub
End Module
Tento příklad vytvoří následující výstup:
99505