Megosztás a következőn keresztül:


Ü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

Lásd még