<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FDatabase_ADO.net%2FXML_Database</id>
		<title>Csharp/C Sharp/Database ADO.net/XML Database - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FDatabase_ADO.net%2FXML_Database"/>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/XML_Database&amp;action=history"/>
		<updated>2026-04-13T20:18:49Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/XML_Database&amp;diff=1017&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/XML_Database&amp;diff=1017&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:19Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:31, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/XML_Database&amp;diff=1018&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/XML_Database&amp;diff=1018&amp;oldid=prev"/>
				<updated>2010-05-26T11:42:45Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==causes the the child rows to be nested within the parent rows in the output XML==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
class NestedXml {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        SqlConnection mySqlConnection = new SqlConnection(&amp;quot;server=localhost;database=Northwind;uid=sa;pwd=sa&amp;quot;);&lt;br /&gt;
        SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
        mySqlCommand.rumandText =&lt;br /&gt;
          &amp;quot;SELECT TOP 2 CustomerID, CompanyName &amp;quot; +&lt;br /&gt;
          &amp;quot;FROM Customers &amp;quot; +&lt;br /&gt;
          &amp;quot;ORDER BY CustomerID;&amp;quot; +&lt;br /&gt;
          &amp;quot;SELECT OrderID, CustomerID, ShipCountry &amp;quot; +&lt;br /&gt;
          &amp;quot;FROM Orders &amp;quot; +&lt;br /&gt;
          &amp;quot;WHERE CustomerID IN (&amp;quot; +&lt;br /&gt;
          &amp;quot;  SELECT TOP 2 CustomerID &amp;quot; +&lt;br /&gt;
          &amp;quot;  FROM Customers &amp;quot; +&lt;br /&gt;
          &amp;quot;  ORDER BY CustomerID &amp;quot; +&lt;br /&gt;
          &amp;quot;)&amp;quot;;&lt;br /&gt;
        SqlDataAdapter mySqlDataAdapter = new SqlDataAdapter();&lt;br /&gt;
        mySqlDataAdapter.SelectCommand = mySqlCommand;&lt;br /&gt;
        DataSet myDataSet = new DataSet();&lt;br /&gt;
        mySqlConnection.Open();&lt;br /&gt;
        int numberOfRows = mySqlDataAdapter.Fill(myDataSet);&lt;br /&gt;
        Console.WriteLine(&amp;quot;numberOfRows = &amp;quot; + numberOfRows);&lt;br /&gt;
        mySqlConnection.Close();&lt;br /&gt;
        DataTable customersDT = myDataSet.Tables[&amp;quot;Table&amp;quot;];&lt;br /&gt;
        DataTable ordersDT = myDataSet.Tables[&amp;quot;Table1&amp;quot;];&lt;br /&gt;
        DataRelation customersOrdersDataRel =&lt;br /&gt;
          new DataRelation(&lt;br /&gt;
            &amp;quot;CustomersOrders&amp;quot;,&lt;br /&gt;
            customersDT.Columns[&amp;quot;CustomerID&amp;quot;],&lt;br /&gt;
            ordersDT.Columns[&amp;quot;CustomerID&amp;quot;]&lt;br /&gt;
          );&lt;br /&gt;
        myDataSet.Relations.Add(&lt;br /&gt;
          customersOrdersDataRel&lt;br /&gt;
        );&lt;br /&gt;
        myDataSet.WriteXml(&amp;quot;nonNestedXmlFile.xml&amp;quot;);&lt;br /&gt;
        myDataSet.Relations[&amp;quot;CustomersOrders&amp;quot;].Nested = true;&lt;br /&gt;
        myDataSet.WriteXml(&amp;quot;nestedXmlFile.xml&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Fill data in DateSet to XmlDocument==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
using System.Xml;&lt;br /&gt;
class UsingXmlDocument {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        SqlConnection mySqlConnection =&lt;br /&gt;
          new SqlConnection(&lt;br /&gt;
            &amp;quot;server=localhost;database=Northwind;uid=sa;pwd=sa&amp;quot;&lt;br /&gt;
          );&lt;br /&gt;
        SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
        mySqlCommand.rumandText =&lt;br /&gt;
          &amp;quot;SELECT TOP 2 CustomerID, CompanyName, Country &amp;quot; +&lt;br /&gt;
          &amp;quot;FROM Customers &amp;quot; +&lt;br /&gt;
          &amp;quot;ORDER BY CustomerID&amp;quot;;&lt;br /&gt;
        SqlDataAdapter mySqlDataAdapter = new SqlDataAdapter();&lt;br /&gt;
        mySqlDataAdapter.SelectCommand = mySqlCommand;&lt;br /&gt;
        DataSet myDataSet = new DataSet();&lt;br /&gt;
        mySqlConnection.Open();&lt;br /&gt;
        mySqlDataAdapter.Fill(myDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
        mySqlConnection.Close();&lt;br /&gt;
        XmlDocument myXmlDocument = new XmlDocument();&lt;br /&gt;
        myXmlDocument.LoadXml(myDataSet.GetXml());&lt;br /&gt;
        Console.WriteLine(&amp;quot;Contents of myXmlDocument:&amp;quot;);&lt;br /&gt;
        myXmlDocument.Save(Console.Out);&lt;br /&gt;
        foreach (XmlNode myXmlNode in myXmlDocument.SelectNodes(&amp;quot;/NewDataSet/Customers&amp;quot;)) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;CustomerID = &amp;quot; + myXmlNode.ChildNodes[0].InnerText);&lt;br /&gt;
            Console.WriteLine(&amp;quot;CompanyName = &amp;quot; + myXmlNode.ChildNodes[1].InnerText);&lt;br /&gt;
            Console.WriteLine(&amp;quot;Country = &amp;quot; + myXmlNode.ChildNodes[2].InnerText);&lt;br /&gt;
        }&lt;br /&gt;
        XmlNode myXmlNode2 = myXmlDocument.SelectSingleNode(&amp;quot;/NewDataSet/Customers[CustomerID=\&amp;quot; ANATR\&amp;quot;]&amp;quot;);&lt;br /&gt;
        Console.WriteLine(&amp;quot;CustomerID = &amp;quot; + myXmlNode2.ChildNodes[0].InnerText);&lt;br /&gt;
        Console.WriteLine(&amp;quot;CompanyName = &amp;quot; + myXmlNode2.ChildNodes[1].InnerText);&lt;br /&gt;
        Console.WriteLine(&amp;quot;Country = &amp;quot; + myXmlNode2.ChildNodes[2].InnerText);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==illustrates how to write and read XML files==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
Mastering Visual C# .NET&lt;br /&gt;
by Jason Price, Mike Gunderloy&lt;br /&gt;
Publisher: Sybex;&lt;br /&gt;
ISBN: 0782129110&lt;br /&gt;
*/&lt;br /&gt;
&lt;br /&gt;
/*&lt;br /&gt;
  Example23_8.cs illustrates how to write and read XML files&lt;br /&gt;
*/&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
public class Example23_8&lt;br /&gt;
{&lt;br /&gt;
  public static void Main()&lt;br /&gt;
  {&lt;br /&gt;
    // formulate a string containing the details of the&lt;br /&gt;
    // database connection&lt;br /&gt;
    string connectionString =&lt;br /&gt;
      &amp;quot;server=localhost;database=Northwind;uid=sa;pwd=sa&amp;quot;;&lt;br /&gt;
    // create a SqlConnection object to connect to the&lt;br /&gt;
    // database, passing the connection string to the constructor&lt;br /&gt;
    SqlConnection mySqlConnection =&lt;br /&gt;
      new SqlConnection(connectionString);&lt;br /&gt;
    // formulate a SELECT statement to retrieve the&lt;br /&gt;
    // CustomerID, CompanyName, ContactName, and Address&lt;br /&gt;
    // columns for the first two rows from the Customers table&lt;br /&gt;
    string selectString =&lt;br /&gt;
      &amp;quot;SELECT CustomerID, CompanyName, ContactName, Address &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM Customers &amp;quot; +&lt;br /&gt;
      &amp;quot;WHERE CustomerID IN (&amp;quot;ALFKI&amp;quot;, &amp;quot;ANATR&amp;quot;)&amp;quot;;&lt;br /&gt;
    // create a SqlCommand object to hold the SELECT statement&lt;br /&gt;
    SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
    // set the CommandText property of the SqlCommand object to&lt;br /&gt;
    // the SELECT string&lt;br /&gt;
    mySqlCommand.rumandText = selectString;&lt;br /&gt;
    // create a SqlDataAdapter object&lt;br /&gt;
    SqlDataAdapter mySqlDataAdapter = new SqlDataAdapter();&lt;br /&gt;
    // set the SelectCommand property of the SqlAdapter object&lt;br /&gt;
    // to the SqlCommand object&lt;br /&gt;
    mySqlDataAdapter.SelectCommand = mySqlCommand;&lt;br /&gt;
    // create a DataSet object to store the results of&lt;br /&gt;
    // the SELECT statement&lt;br /&gt;
    DataSet myDataSet = new DataSet();&lt;br /&gt;
    // open the database connection using the&lt;br /&gt;
    // Open() method of the SqlConnection object&lt;br /&gt;
    mySqlConnection.Open();&lt;br /&gt;
    // use the Fill() method of the SqlDataAdapter object to&lt;br /&gt;
    // retrieve the rows from the table, storing the rows locally&lt;br /&gt;
    // in a DataTable of the DataSet object&lt;br /&gt;
    Console.WriteLine(&amp;quot;Retrieving rows from the Customers table&amp;quot;);&lt;br /&gt;
    mySqlDataAdapter.Fill(myDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
    // get the DataTable object from the DataSet object&lt;br /&gt;
    DataTable myDataTable = myDataSet.Tables[&amp;quot;Customers&amp;quot;];&lt;br /&gt;
    // use the WriteXml() method to write the DataSet out to an&lt;br /&gt;
    // XML file&lt;br /&gt;
    Console.WriteLine(&amp;quot;Writing rows out to an XML file named &amp;quot; +&lt;br /&gt;
      &amp;quot;myXmlFile.xml&amp;quot;);&lt;br /&gt;
    myDataSet.WriteXml(&amp;quot;myXmlFile.xml&amp;quot;);&lt;br /&gt;
    // use the WriteXmlSchema() method to write the schema of the&lt;br /&gt;
    // DataSet out to an XML file&lt;br /&gt;
    Console.WriteLine(&amp;quot;Writing schema out to an XML file named &amp;quot; +&lt;br /&gt;
      &amp;quot;myXmlSchemaFile.xml&amp;quot;);&lt;br /&gt;
    myDataSet.WriteXmlSchema(&amp;quot;myXmlSchemaFile.xml&amp;quot;);&lt;br /&gt;
    // use the Clear() method to clear the current rows in the DataSet&lt;br /&gt;
    myDataSet.Clear();&lt;br /&gt;
    // use the ReadXml() method to read the contents of the XML file&lt;br /&gt;
    // into the DataSet&lt;br /&gt;
    myDataSet.ReadXml(&amp;quot;myXmlFile.xml&amp;quot;);&lt;br /&gt;
    // display the columns for each row in the DataTable,&lt;br /&gt;
    // using a DataRow object to access each row in the DataTable&lt;br /&gt;
    foreach (DataRow myDataRow in myDataTable.Rows)&lt;br /&gt;
    {&lt;br /&gt;
      Console.WriteLine(&amp;quot;CustomerID = &amp;quot; + myDataRow[&amp;quot;CustomerID&amp;quot;]);&lt;br /&gt;
      Console.WriteLine(&amp;quot;CompanyName = &amp;quot; + myDataRow[&amp;quot;CompanyName&amp;quot;]);&lt;br /&gt;
      Console.WriteLine(&amp;quot;ContactName = &amp;quot; + myDataRow[&amp;quot;ContactName&amp;quot;]);&lt;br /&gt;
      Console.WriteLine(&amp;quot;Address = &amp;quot; + myDataRow[&amp;quot;Address&amp;quot;]);&lt;br /&gt;
    }&lt;br /&gt;
    // close the database connection using the Close() method&lt;br /&gt;
    // of the SqlConnection object&lt;br /&gt;
    mySqlConnection.Close();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Obtain an XML Document from a SQL Server Query==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Xml;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
public class XmlQueryExample {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        using (SqlConnection con = new SqlConnection()) {&lt;br /&gt;
            con.ConnectionString = &amp;quot;Data Source = localhost;&amp;quot; + &lt;br /&gt;
                &amp;quot;Database = Northwind; Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
            SqlCommand com = con.CreateCommand();&lt;br /&gt;
            com.rumandType = CommandType.Text;&lt;br /&gt;
            com.rumandText = &amp;quot;SELECT CustomerID, CompanyName&amp;quot; + &lt;br /&gt;
                &amp;quot; FROM Customers FOR XML AUTO&amp;quot;;&lt;br /&gt;
            XmlReader reader = null;&lt;br /&gt;
            try {&lt;br /&gt;
                con.Open();&lt;br /&gt;
                reader = com.ExecuteXmlReader();&lt;br /&gt;
                while (reader.Read()) {&lt;br /&gt;
                    Console.Write(reader.Name);&lt;br /&gt;
                    if (reader.HasAttributes) {&lt;br /&gt;
                        for (int i = 0; i &amp;lt; reader.AttributeCount; i++) {&lt;br /&gt;
                            reader.MoveToAttribute(i);&lt;br /&gt;
                            Console.Write(&amp;quot;  {0}: {1}&amp;quot;,reader.Name, reader.Value);&lt;br /&gt;
                        }&lt;br /&gt;
                        reader.MoveToElement();  &lt;br /&gt;
                    }&lt;br /&gt;
                }&lt;br /&gt;
            } catch (Exception ex) {&lt;br /&gt;
                Console.WriteLine(ex.ToString());&lt;br /&gt;
            } finally {&lt;br /&gt;
                if (reader != null) reader.Close();&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Persisting A Dataset To An XML File==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
 * C# Programmers Pocket Consultant&lt;br /&gt;
 * Author: Gregory S. MacBeth&lt;br /&gt;
 * Email: gmacbeth@comporium.net&lt;br /&gt;
 * Create Date: June 27, 2003&lt;br /&gt;
 * Last Modified Date:&lt;br /&gt;
 * Version: 1&lt;br /&gt;
 */&lt;br /&gt;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.OleDb;&lt;br /&gt;
namespace Client.Chapter_13___ADO.NET&lt;br /&gt;
{&lt;br /&gt;
    public class PersistingADatasetToAnXMLFile&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            OleDbConnection MyConnection = new OleDbConnection(@&amp;quot;Provider=Microsft.Jet.OLEDB.4.0; Data Source = c:\MyAccessDB.mdb&amp;quot;);&lt;br /&gt;
            OleDbDataAdapter MyAdapter = new OleDbDataAdapter(&amp;quot;SELECT Column1, Column2, Column3 FROM MyTable&amp;quot;, MyConnection);&lt;br /&gt;
            DataSet MyDataSet = new DataSet();&lt;br /&gt;
            MyAdapter.Fill(MyDataSet, &amp;quot;MyTable&amp;quot;);&lt;br /&gt;
            MyDataSet.WriteXml(@&amp;quot;c:\MyDatSet.xml&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Reading An XML File Into A Dataset==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
 * C# Programmers Pocket Consultant&lt;br /&gt;
 * Author: Gregory S. MacBeth&lt;br /&gt;
 * Email: gmacbeth@comporium.net&lt;br /&gt;
 * Create Date: June 27, 2003&lt;br /&gt;
 * Last Modified Date:&lt;br /&gt;
 * Version: 1&lt;br /&gt;
 */&lt;br /&gt;
using System;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Data;&lt;br /&gt;
&lt;br /&gt;
namespace Client.Chapter_13___ADO.NET&lt;br /&gt;
{&lt;br /&gt;
    public class ReadingAnXMLFileIntoADataset&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            string MyXMLDoc = @&amp;quot;&amp;lt;?xml version=&amp;quot;1.0&amp;quot;&amp;gt;?&lt;br /&gt;
                            &amp;lt;title&amp;gt; MyExample&amp;lt;/title&amp;gt;&amp;quot;;&lt;br /&gt;
            StringReader MyStringReader = new StringReader(MyXMLDoc);&lt;br /&gt;
            DataSet MyDataSet = new DataSet();&lt;br /&gt;
            MyDataSet.ReadXml(MyStringReader);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>