Köra SQL-frågor med metoden ExecuteXMLReader

gäller för:SQL ServerAzure SQL Database

Istället för att använda ExecuteToStream-metoden kan du använda ExecuteXmlReader-metoden i SqlXmlCommand-objektet för att exekvera kommandon. Denna metod returnerar ett XmlReader-objekt som kan användas för vidare bearbetning av resultatet (vilket i detta exempel är att skriva ut element- eller attributnamn och värden).

Anmärkning

I koden måste du ange namnet på instansen av Microsoft SQL Server i anslutningssträngen.

using System;  
using Microsoft.Data.SqlXml;  
using System.IO;  
using System.Xml;  
   class Test  
   {  
      static string ConnString = "Provider=SQLOLEDB;Server=(local);database=AdventureWorks2022;Integrated Security=SSPI";  
      public static int testParams()  
      {  
         SqlXmlParameter p;  
         XmlReader Reader;  
         XmlTextWriter tw;  
         SqlXmlCommand cmd = new SqlXmlCommand(ConnString);  
         cmd.CommandText = "select FirstName, LastName from Person.Person where LastName = ? For XML Auto";  
         p = cmd.CreateParameter();  
         p.Value = "Achong";  
         Reader = cmd.ExecuteXmlReader();  
            tw = new XmlTextWriter(Console.Out);  
         Reader.MoveToContent();  
         tw.WriteNode(Reader, false);  
         tw.Flush();  
         tw.Close();  
         Reader.Close();  
  
         return 0;  
      }  
  
      static int Main(string[] args)  
      {  
         testParams();  
         return 0;  
      }  
   }  

Testa programmet

  1. Se till att du har Microsoft .NET Framework installerat på din dator.

  2. Spara C#-koden (DocSample.cs) som finns i detta ämne i en mapp.

  3. Komplisera koden. För att kompilera koden i kommandoprompten, använd:

    csc /reference:Microsoft.Data.SqlXML.dll DocSample.cs  
    

    Detta skapar en exekverbar fil (DocSample.exe).

  4. Vid kommandoprompten, utför DocSample.exe.