<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FADO.Net%2FDataRelation</id>
		<title>Csharp/CSharp Tutorial/ADO.Net/DataRelation - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FCSharp_Tutorial%2FADO.Net%2FDataRelation"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataRelation&amp;action=history"/>
		<updated>2026-04-30T01:18:40Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataRelation&amp;diff=6468&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataRelation&amp;diff=6468&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:53Z</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://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataRelation&amp;diff=6469&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataRelation&amp;diff=6469&amp;oldid=prev"/>
				<updated>2010-05-26T12:19:09Z</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;==DataRelation Example==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;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;
  {&lt;br /&gt;
    static void Main(string[] args)&lt;br /&gt;
    {&lt;br /&gt;
      SqlConnection thisConnection = new SqlConnection(&lt;br /&gt;
                @&amp;quot;Data Source=.\SQLEXPRESS;&amp;quot; +&lt;br /&gt;
                @&amp;quot;AttachDbFilename=&amp;quot;NORTHWND.MDF&amp;quot;;&amp;quot; +&lt;br /&gt;
                @&amp;quot;Integrated Security=True;Connect Timeout=30;User Instance=true&amp;quot;);&lt;br /&gt;
      SqlDataAdapter thisAdapter = new SqlDataAdapter(&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(&amp;quot;SELECT * FROM Customers&amp;quot;, thisConnection);&lt;br /&gt;
      SqlDataAdapter orderAdapter = new SqlDataAdapter(&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;
      {&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;
        {&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;
            custOrderRel.Nested = true;&lt;br /&gt;
            thisDataSet.WriteXml(&amp;quot;nwinddata.xml&amp;quot;);&lt;br /&gt;
            thisConnection.Close();&lt;br /&gt;
    }&lt;br /&gt;
  }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Define DataRelation==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
public class XmlRelations&lt;br /&gt;
{&lt;br /&gt;
    private static string connectionString = &amp;quot;Data Source=localhost;Initial Catalog=Northwind;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
    private static string categorySQL = &amp;quot;SELECT CategoryID, CategoryName,Description FROM Categories&amp;quot;;&lt;br /&gt;
    private static string productSQL = &amp;quot;SELECT ProductID, ProductName, CategoryID FROM Products&amp;quot;;&lt;br /&gt;
    public static void Main() &lt;br /&gt;
    {&lt;br /&gt;
        SqlConnection con = new SqlConnection(connectionString);&lt;br /&gt;
        SqlCommand com = new SqlCommand(categorySQL, con);&lt;br /&gt;
        SqlDataAdapter adapter = new SqlDataAdapter(com);&lt;br /&gt;
        DataSet ds = new DataSet(&amp;quot;Nortwind&amp;quot;);&lt;br /&gt;
        con.Open();&lt;br /&gt;
        adapter.FillSchema(ds, SchemaType.Mapped, &amp;quot;Categories&amp;quot;);&lt;br /&gt;
        adapter.Fill(ds, &amp;quot;Categories&amp;quot;);&lt;br /&gt;
        adapter.SelectCommand.rumandText = productSQL;&lt;br /&gt;
        adapter.FillSchema(ds, SchemaType.Mapped, &amp;quot;Products&amp;quot;);&lt;br /&gt;
        adapter.Fill(ds, &amp;quot;Products&amp;quot;);&lt;br /&gt;
        con.Close();&lt;br /&gt;
        DataColumn parentCol = ds.Tables[&amp;quot;Categories&amp;quot;].Columns[&amp;quot;CategoryID&amp;quot;];&lt;br /&gt;
        DataColumn childCol = ds.Tables[&amp;quot;Products&amp;quot;].Columns[&amp;quot;CategoryID&amp;quot;];&lt;br /&gt;
        DataRelation relation = new DataRelation(&amp;quot;Cat_Prod&amp;quot;, parentCol, childCol);&lt;br /&gt;
        ds.Relations.Add(relation);&lt;br /&gt;
        relation.Nested = true;&lt;br /&gt;
        ds.WriteXml(&amp;quot;mydata.xml&amp;quot;);&lt;br /&gt;
        ds.WriteXml(Console.Out);&lt;br /&gt;
    }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Navigate a many-to-many relationship.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt;using System;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.Data.SqlClient;&lt;br /&gt;
public class AddCustomer&lt;br /&gt;
{&lt;br /&gt;
  public static void Main() &lt;br /&gt;
  {&lt;br /&gt;
    string connectionString = &amp;quot;Data Source=localhost;Initial Catalog=pubs;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
    string SQL = &amp;quot;SELECT au_lname, au_fname, au_id FROM Authors&amp;quot;;&lt;br /&gt;
    SqlConnection con = new SqlConnection(connectionString);&lt;br /&gt;
    SqlCommand cmd = new SqlCommand(SQL, con);&lt;br /&gt;
    SqlDataAdapter adapter = new SqlDataAdapter(cmd);&lt;br /&gt;
    DataSet ds = new DataSet();&lt;br /&gt;
    con.Open();&lt;br /&gt;
    adapter.Fill(ds, &amp;quot;Authors&amp;quot;);&lt;br /&gt;
    cmd.rumandText = &amp;quot;SELECT au_id, title_id FROM TitleAuthor&amp;quot;;&lt;br /&gt;
    adapter.Fill(ds, &amp;quot;TitleAuthor&amp;quot;);&lt;br /&gt;
    cmd.rumandText = &amp;quot;SELECT title_id, title FROM Titles&amp;quot;;&lt;br /&gt;
    adapter.Fill(ds, &amp;quot;Titles&amp;quot;);&lt;br /&gt;
    con.Close();&lt;br /&gt;
    DataRelation titles_titleAuthor = new DataRelation(&amp;quot;&amp;quot;, ds.Tables[&amp;quot;Titles&amp;quot;].Columns[&amp;quot;title_id&amp;quot;], ds.Tables[&amp;quot;TitleAuthor&amp;quot;].Columns[&amp;quot;title_id&amp;quot;]);&lt;br /&gt;
    DataRelation authors_titleAuthor = new DataRelation(&amp;quot;&amp;quot;, ds.Tables[&amp;quot;Authors&amp;quot;].Columns[&amp;quot;au_id&amp;quot;], ds.Tables[&amp;quot;TitleAuthor&amp;quot;].Columns[&amp;quot;au_id&amp;quot;]);&lt;br /&gt;
    ds.Relations.Add(titles_titleAuthor);&lt;br /&gt;
    ds.Relations.Add(authors_titleAuthor);&lt;br /&gt;
    foreach (DataRow rowAuthor in ds.Tables[&amp;quot;Authors&amp;quot;].Rows)&lt;br /&gt;
    {&lt;br /&gt;
        Console.WriteLine(rowAuthor[&amp;quot;au_fname&amp;quot;]);&lt;br /&gt;
        Console.WriteLine(rowAuthor[&amp;quot;au_lname&amp;quot;]);&lt;br /&gt;
        foreach (DataRow rowTitleAuthor in rowAuthor.GetChildRows(authors_titleAuthor))&lt;br /&gt;
        {&lt;br /&gt;
            foreach (DataRow rowTitle in rowTitleAuthor.GetParentRows(titles_titleAuthor))&lt;br /&gt;
            {&lt;br /&gt;
                Console.WriteLine(rowTitle[&amp;quot;title&amp;quot;]);&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>