<?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%2FDataRelation</id>
		<title>Csharp/C Sharp/Database ADO.net/DataRelation - История изменений</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%2FDataRelation"/>
		<link rel="alternate" type="text/html" href="http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/DataRelation&amp;action=history"/>
		<updated>2026-04-13T20:18:18Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/DataRelation&amp;diff=987&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/DataRelation&amp;diff=987&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/DataRelation&amp;diff=988&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/DataRelation&amp;diff=988&amp;oldid=prev"/>
				<updated>2010-05-26T11:42:37Z</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;==More than one Relations==&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;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
class Program {&lt;br /&gt;
    static void Main(string[] args) {&lt;br /&gt;
        SqlConnection thisConnection = new SqlConnection(@&amp;quot;Server=(local)\sqlexpress;Integrated Security=True;&amp;quot; +&lt;br /&gt;
             &amp;quot;Database=northwind&amp;quot;);&lt;br /&gt;
        DataSet thisDataSet = new DataSet();&lt;br /&gt;
        SqlDataAdapter custAdapter = new SqlDataAdapter(&amp;quot;SELECT * FROM Customers&amp;quot;, thisConnection);&lt;br /&gt;
        custAdapter.Fill(thisDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
        SqlDataAdapter orderAdapter = new SqlDataAdapter(&amp;quot;SELECT * FROM Orders&amp;quot;, thisConnection);&lt;br /&gt;
        orderAdapter.Fill(thisDataSet, &amp;quot;Orders&amp;quot;);&lt;br /&gt;
        SqlDataAdapter detailAdapter = new SqlDataAdapter(&amp;quot;SELECT * FROM [Order Details]&amp;quot;, thisConnection);&lt;br /&gt;
        detailAdapter.Fill(thisDataSet, &amp;quot;Order Details&amp;quot;);&lt;br /&gt;
        SqlDataAdapter prodAdapter = new SqlDataAdapter(&amp;quot;SELECT * FROM Products&amp;quot;, thisConnection);&lt;br /&gt;
        prodAdapter.Fill(thisDataSet, &amp;quot;Products&amp;quot;);&lt;br /&gt;
        DataRelation custOrderRel = thisDataSet.Relations.Add(&amp;quot;CustOrders&amp;quot;,&lt;br /&gt;
                    thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;],&lt;br /&gt;
                    thisDataSet.Tables[&amp;quot;Orders&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;]);&lt;br /&gt;
        DataRelation orderDetailRel = thisDataSet.Relations.Add(&amp;quot;OrderDetail&amp;quot;,&lt;br /&gt;
                    thisDataSet.Tables[&amp;quot;Orders&amp;quot;].Columns[&amp;quot;OrderID&amp;quot;],&lt;br /&gt;
                    thisDataSet.Tables[&amp;quot;Order Details&amp;quot;].Columns[&amp;quot;OrderID&amp;quot;]);&lt;br /&gt;
        DataRelation orderProductRel = thisDataSet.Relations.Add(&lt;br /&gt;
          &amp;quot;OrderProducts&amp;quot;, thisDataSet.Tables[&amp;quot;Products&amp;quot;].Columns[&amp;quot;ProductID&amp;quot;],&lt;br /&gt;
           thisDataSet.Tables[&amp;quot;Order Details&amp;quot;].Columns[&amp;quot;ProductID&amp;quot;]);&lt;br /&gt;
        foreach (DataRow custRow in thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;Customer ID: &amp;quot; + custRow[&amp;quot;CustomerID&amp;quot;]);&lt;br /&gt;
            foreach (DataRow orderRow in custRow.GetChildRows(custOrderRel)) {&lt;br /&gt;
                Console.WriteLine(&amp;quot;\tOrder ID: &amp;quot; + orderRow[&amp;quot;OrderID&amp;quot;]);&lt;br /&gt;
                Console.WriteLine(&amp;quot;\t\tOrder Date: &amp;quot; + orderRow[&amp;quot;OrderDate&amp;quot;]);&lt;br /&gt;
                foreach (DataRow detailRow in&lt;br /&gt;
                         orderRow.GetChildRows(orderDetailRel)) {&lt;br /&gt;
                    Console.WriteLine(&amp;quot;\t\tProduct: &amp;quot; +&lt;br /&gt;
                    detailRow.GetParentRow(orderProductRel)[&amp;quot;ProductName&amp;quot;]);&lt;br /&gt;
                    Console.WriteLine(&amp;quot;\t\tQuantity: &amp;quot; + detailRow[&amp;quot;Quantity&amp;quot;]);&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
        thisConnection.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;
==Setting the Nested property of a DataRelation to true==&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;
{&lt;br /&gt;
  public static void Main()&lt;br /&gt;
  {&lt;br /&gt;
    SqlConnection mySqlConnection =new SqlConnection(&amp;quot;server=(local)\\SQLEXPRESS;database=MyDatabase;Integrated Security=SSPI;&amp;quot;);&lt;br /&gt;
    SqlCommand mySqlCommand = mySqlConnection.CreateCommand();&lt;br /&gt;
    mySqlCommand.rumandText =&lt;br /&gt;
      &amp;quot;SELECT TOP 2 EmployeeID, CompanyName &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM Employee &amp;quot; +&lt;br /&gt;
      &amp;quot;ORDER BY EmployeeID;&amp;quot;  +&lt;br /&gt;
      &amp;quot;SELECT DeptID, EmployeeID, City &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM Dept &amp;quot; +&lt;br /&gt;
      &amp;quot;WHERE EmployeeID IN (&amp;quot; +&lt;br /&gt;
      &amp;quot;  SELECT TOP 2 EmployeeID &amp;quot; +&lt;br /&gt;
      &amp;quot;  FROM Employee &amp;quot; +&lt;br /&gt;
      &amp;quot;  ORDER BY EmployeeID &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 customersDeptDataRel =&lt;br /&gt;
      new DataRelation(&lt;br /&gt;
        &amp;quot;EmployeeDept&amp;quot;,&lt;br /&gt;
        customersDT.Columns[&amp;quot;EmployeeID&amp;quot;],&lt;br /&gt;
        ordersDT.Columns[&amp;quot;EmployeeID&amp;quot;]&lt;br /&gt;
      );&lt;br /&gt;
    myDataSet.Relations.Add(&lt;br /&gt;
      customersDeptDataRel&lt;br /&gt;
    );&lt;br /&gt;
    myDataSet.WriteXml(&amp;quot;nonNestedXmlFile.xml&amp;quot;);&lt;br /&gt;
    myDataSet.Relations[&amp;quot;EmployeeDept&amp;quot;].Nested = true;&lt;br /&gt;
    myDataSet.WriteXml(&amp;quot;nestedXmlFile.xml&amp;quot;);&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;
==Set up DataRelation ==&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;
using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
class Program {&lt;br /&gt;
    static void Main(string[] args) {&lt;br /&gt;
        SqlConnection thisConnection = new SqlConnection(&lt;br /&gt;
             @&amp;quot;Server=(local)\sqlexpress;Integrated Security=True;&amp;quot; +&lt;br /&gt;
             &amp;quot;Database=northwind&amp;quot;);&lt;br /&gt;
        SqlDataAdapter thisAdapter = new SqlDataAdapter(&lt;br /&gt;
             &amp;quot;SELECT CustomerID, CompanyName FROM Customers&amp;quot;, thisConnection);&lt;br /&gt;
        SqlCommandBuilder thisBuilder = new SqlCommandBuilder(thisAdapter);&lt;br /&gt;
        DataSet thisDataSet = new DataSet();&lt;br /&gt;
        SqlDataAdapter custAdapter = new SqlDataAdapter(&lt;br /&gt;
             &amp;quot;SELECT * FROM Customers&amp;quot;, thisConnection);&lt;br /&gt;
        SqlDataAdapter orderAdapter = new SqlDataAdapter(&lt;br /&gt;
             &amp;quot;SELECT * FROM Orders&amp;quot;, thisConnection);&lt;br /&gt;
        custAdapter.Fill(thisDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
        orderAdapter.Fill(thisDataSet, &amp;quot;Orders&amp;quot;);&lt;br /&gt;
        DataRelation custOrderRel = thisDataSet.Relations.Add(&amp;quot;CustOrders&amp;quot;,&lt;br /&gt;
             thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;],&lt;br /&gt;
             thisDataSet.Tables[&amp;quot;Orders&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;]);&lt;br /&gt;
        foreach (DataRow custRow in thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;Customer ID: &amp;quot; + custRow[&amp;quot;CustomerID&amp;quot;] +&lt;br /&gt;
                              &amp;quot; Name: &amp;quot; + custRow[&amp;quot;CompanyName&amp;quot;]);&lt;br /&gt;
            foreach (DataRow orderRow in custRow.GetChildRows(custOrderRel)) {&lt;br /&gt;
                Console.WriteLine(&amp;quot;  Order ID: &amp;quot; + orderRow[&amp;quot;OrderID&amp;quot;]);&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
        thisConnection.Close();&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>