Üres lekérdezési eredményhalmazok hibakeresése (LINQ–XML)
Az XML-fák lekérdezése során az egyik leggyakoribb probléma az, hogy ha az XML-fa alapértelmezett névtérrel rendelkezik, a fejlesztő néha úgy írja le a lekérdezést, mintha az XML nem egy névtérben lenne.
A cikk első példái azt mutatják be, hogyan töltődik be az XML az alapértelmezett névtérbe, majd nem megfelelően kérdezhető le.
A második példakészlet a szükséges javításokat mutatja be, hogy lekérdezhesse az XML-t egy névtérben.
További információ: Névterek áttekintése.
Példa: Egy névtérben lévő XML-lekérdezés helytelen lekérdezése
Ez a példa az XML névtérben való létrehozását mutatja be, valamint egy üres eredményhalmazt visszaadó lekérdezést.
XElement root = XElement.Parse(
@"<Root xmlns='http://www.adventure-works.com'>
<Child>1</Child>
<Child>2</Child>
<Child>3</Child>
<AnotherChild>4</AnotherChild>
<AnotherChild>5</AnotherChild>
<AnotherChild>6</AnotherChild>
</Root>");
IEnumerable<XElement> c1 =
from el in root.Elements("Child")
select el;
Console.WriteLine("Result set follows:");
foreach (XElement el in c1)
Console.WriteLine((int)el);
Console.WriteLine("End of result set");
Dim root As XElement = _
<Root xmlns='http://www.adventure-works.com'>
<Child>1</Child>
<Child>2</Child>
<Child>3</Child>
<AnotherChild>4</AnotherChild>
<AnotherChild>5</AnotherChild>
<AnotherChild>6</AnotherChild>
</Root>
Dim c1 As IEnumerable(Of XElement) = _
From el In root.<Child> _
Select el
Console.WriteLine("Result set follows:")
For Each el As XElement In c1
Console.WriteLine(el.Value)
Next
Console.WriteLine("End of result set")
A példa a következő eredményt hozza létre:
Result set follows:
End of result set
Példa: Egy névtérben lévő XML-lekérdezés megfelelő lekérdezése
Ez a példa egy névtérben és egy megfelelően kódolt lekérdezésben mutatja be az XML létrehozását.
A megoldás egy objektum deklarálása és inicializálása XNamespace , valamint az objektumok megadásakor XName történő használata. Ebben az esetben a metódus argumentuma Elements egy XName objektum.
XElement root = XElement.Parse(
@"<Root xmlns='http://www.adventure-works.com'>
<Child>1</Child>
<Child>2</Child>
<Child>3</Child>
<AnotherChild>4</AnotherChild>
<AnotherChild>5</AnotherChild>
<AnotherChild>6</AnotherChild>
</Root>");
XNamespace aw = "http://www.adventure-works.com";
IEnumerable<XElement> c1 =
from el in root.Elements(aw + "Child")
select el;
Console.WriteLine("Result set follows:");
foreach (XElement el in c1)
Console.WriteLine((int)el);
Console.WriteLine("End of result set");
Imports <xmlns="http://www.adventure-works.com">
Module Module1
Sub Main()
Dim root As XElement = _
<Root xmlns='http://www.adventure-works.com'>
<Child>1</Child>
<Child>2</Child>
<Child>3</Child>
<AnotherChild>4</AnotherChild>
<AnotherChild>5</AnotherChild>
<AnotherChild>6</AnotherChild>
</Root>
Dim c1 As IEnumerable(Of XElement) = _
From el In root.<Child> _
Select el
Console.WriteLine("Result set follows:")
For Each el As XElement In c1
Console.WriteLine(CInt(el))
Next
Console.WriteLine("End of result set")
End Sub
End Module
A példa a következő eredményt hozza létre:
Result set follows:
1
2
3
End of result set