<?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%2FDataColumn</id>
		<title>Csharp/CSharp Tutorial/ADO.Net/DataColumn - История изменений</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%2FDataColumn"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataColumn&amp;action=history"/>
		<updated>2026-04-30T01:18:00Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/CSharp_Tutorial/ADO.Net/DataColumn&amp;diff=6472&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/DataColumn&amp;diff=6472&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/DataColumn&amp;diff=6473&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/DataColumn&amp;diff=6473&amp;oldid=prev"/>
				<updated>2010-05-26T12:19:10Z</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;==Add an expression column to the table==&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;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            string sqlConnectString = &amp;quot;Data Source=(local);Integrated security=SSPI;Initial Catalog=AdventureWorks;&amp;quot;;&lt;br /&gt;
            string sqlSelect = &amp;quot;SELECT TOP 5 * FROM Sales.SalesOrderDetail&amp;quot;;&lt;br /&gt;
            SqlDataAdapter da = new SqlDataAdapter(sqlSelect, sqlConnectString);&lt;br /&gt;
            DataTable dt = new DataTable();&lt;br /&gt;
            da.Fill(dt);&lt;br /&gt;
            &lt;br /&gt;
            dt.Columns.Add(new DataColumn(&amp;quot;ExtendedPrice&amp;quot;, typeof(Decimal),&amp;quot;UnitPrice * (1 - UnitPriceDiscount) * OrderQty&amp;quot;));&lt;br /&gt;
            foreach (DataRow row in dt.Rows)&lt;br /&gt;
                Console.WriteLine(&amp;quot;ID = {0}, UnitPrice = {1}, &amp;quot; +&lt;br /&gt;
                    &amp;quot;Disc = {2}, Qty = {3}, Total = {4}&amp;quot;,&lt;br /&gt;
                    row[&amp;quot;SalesOrderDetailID&amp;quot;], row[&amp;quot;UnitPrice&amp;quot;],&lt;br /&gt;
                    row[&amp;quot;UnitPriceDiscount&amp;quot;], row[&amp;quot;OrderQty&amp;quot;],&lt;br /&gt;
                    row[&amp;quot;ExtendedPrice&amp;quot;]);&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Creating an Autoincrementing Primary Key==&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;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            DataTable dt = new DataTable();&lt;br /&gt;
            DataColumn pkCol = dt.Columns.Add(&amp;quot;Id&amp;quot;, typeof(int));&lt;br /&gt;
            dt.Columns.Add(&amp;quot;Field1&amp;quot;, typeof(string)).MaxLength = 50;&lt;br /&gt;
            dt.PrimaryKey = new DataColumn[] {dt.Columns[&amp;quot;Id&amp;quot;]};&lt;br /&gt;
            pkCol.AutoIncrement = true;&lt;br /&gt;
            pkCol.AutoIncrementSeed = 100;&lt;br /&gt;
            pkCol.AutoIncrementStep = 10;&lt;br /&gt;
            for (int i = 1; i &amp;lt;= 5; i++)&lt;br /&gt;
                dt.Rows.Add(new object[] {null, &amp;quot;Value &amp;quot; + i });&lt;br /&gt;
            foreach (DataRow row in dt.Rows)&lt;br /&gt;
                Console.WriteLine(&amp;quot;Id = {0}\tField1 = {1}&amp;quot;,row[&amp;quot;Id&amp;quot;], row[&amp;quot;Field1&amp;quot;]);&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Find data by primary key, if not found add to database==&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;
&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;
      thisAdapter.Fill(thisDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
      Console.WriteLine(&amp;quot;# rows before change: {0}&amp;quot;,thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows.Count);&lt;br /&gt;
      DataColumn[] keys = new DataColumn[1];&lt;br /&gt;
      keys[0] = thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;];&lt;br /&gt;
      thisDataSet.Tables[&amp;quot;Customers&amp;quot;].PrimaryKey = keys;&lt;br /&gt;
      DataRow findRow = thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows.Find(&amp;quot;1&amp;quot;);&lt;br /&gt;
      if (findRow == null)&lt;br /&gt;
      {&lt;br /&gt;
        DataRow thisRow = thisDataSet.Tables[&amp;quot;Customers&amp;quot;].NewRow();&lt;br /&gt;
        thisRow[&amp;quot;CustomerID&amp;quot;] = &amp;quot;1&amp;quot;;&lt;br /&gt;
        thisRow[&amp;quot;CompanyName&amp;quot;] = &amp;quot;Abc Ltd.&amp;quot;;&lt;br /&gt;
        thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows.Add(thisRow);&lt;br /&gt;
        if ((findRow = thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows.Find(&amp;quot;1&amp;quot;)) != null)&lt;br /&gt;
        {&lt;br /&gt;
          Console.WriteLine(&amp;quot;success&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
      thisAdapter.Update(thisDataSet, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
      Console.WriteLine(thisDataSet.Tables[&amp;quot;Customers&amp;quot;].Rows.Count);&lt;br /&gt;
      thisConnection.Close();&lt;br /&gt;
    }&lt;br /&gt;
  }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Output DataSet as Binary file==&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.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
using System.Data;&lt;br /&gt;
using System.IO;&lt;br /&gt;
using System.Runtime.Serialization.Formatters.Binary;&lt;br /&gt;
  class Program&lt;br /&gt;
  {&lt;br /&gt;
    static void Main(string[] args)&lt;br /&gt;
    {&lt;br /&gt;
      DataSet carsInventoryDS = new DataSet(&amp;quot;Car&amp;quot;);&lt;br /&gt;
      &lt;br /&gt;
      carsInventoryDS.ExtendedProperties[&amp;quot;TimeStamp&amp;quot;] = DateTime.Now;&lt;br /&gt;
      carsInventoryDS.ExtendedProperties[&amp;quot;DataSetID&amp;quot;] = Guid.NewGuid();&lt;br /&gt;
      carsInventoryDS.ExtendedProperties[&amp;quot;Company&amp;quot;] = &amp;quot;Training&amp;quot;;&lt;br /&gt;
      DataColumn carIDColumn = new DataColumn(&amp;quot;CarID&amp;quot;, typeof(int));&lt;br /&gt;
      carIDColumn.Caption = &amp;quot;Car ID&amp;quot;;&lt;br /&gt;
      carIDColumn.ReadOnly = true;&lt;br /&gt;
      carIDColumn.AllowDBNull = false;&lt;br /&gt;
      carIDColumn.Unique = true;&lt;br /&gt;
      carIDColumn.AutoIncrement = true;&lt;br /&gt;
      carIDColumn.AutoIncrementSeed = 0;&lt;br /&gt;
      carIDColumn.AutoIncrementStep = 1;&lt;br /&gt;
      DataColumn carMakeColumn = new DataColumn(&amp;quot;Make&amp;quot;, typeof(string));&lt;br /&gt;
      DataColumn carColorColumn = new DataColumn(&amp;quot;Color&amp;quot;, typeof(string));&lt;br /&gt;
      DataColumn carPetNameColumn = new DataColumn(&amp;quot;PetName&amp;quot;, typeof(string));&lt;br /&gt;
      carPetNameColumn.Caption = &amp;quot;Pet Name&amp;quot;;&lt;br /&gt;
      DataTable inventoryTable = new DataTable(&amp;quot;Inventory&amp;quot;);&lt;br /&gt;
      inventoryTable.Columns.AddRange(new DataColumn[] { carIDColumn, carMakeColumn, carColorColumn, carPetNameColumn });&lt;br /&gt;
      DataRow carRow = inventoryTable.NewRow();&lt;br /&gt;
      carRow[&amp;quot;Make&amp;quot;] = &amp;quot;BMW&amp;quot;;&lt;br /&gt;
      carRow[&amp;quot;Color&amp;quot;] = &amp;quot;Black&amp;quot;;&lt;br /&gt;
      carRow[&amp;quot;PetName&amp;quot;] = &amp;quot;Hamlet&amp;quot;;&lt;br /&gt;
      inventoryTable.Rows.Add(carRow);&lt;br /&gt;
      carRow = inventoryTable.NewRow();&lt;br /&gt;
      carRow[1] = &amp;quot;A&amp;quot;;&lt;br /&gt;
      carRow[2] = &amp;quot;B&amp;quot;;&lt;br /&gt;
      carRow[3] = &amp;quot;C&amp;quot;;&lt;br /&gt;
      inventoryTable.Rows.Add(carRow);&lt;br /&gt;
      inventoryTable.PrimaryKey = new DataColumn[] { inventoryTable.Columns[0] };&lt;br /&gt;
      carsInventoryDS.Tables.Add(inventoryTable);&lt;br /&gt;
      &lt;br /&gt;
      carsInventoryDS.RemotingFormat = SerializationFormat.Binary;&lt;br /&gt;
      FileStream fs = new FileStream(&amp;quot;BinaryCars.bin&amp;quot;, FileMode.Create);&lt;br /&gt;
      BinaryFormatter bFormat = new BinaryFormatter();&lt;br /&gt;
      bFormat.Serialize(fs, carsInventoryDS);&lt;br /&gt;
      fs.Close();&lt;br /&gt;
      carsInventoryDS.Clear();&lt;br /&gt;
      fs = new FileStream(&amp;quot;BinaryCars.bin&amp;quot;, FileMode.Open);&lt;br /&gt;
      DataSet data = (DataSet)bFormat.Deserialize(fs);&lt;br /&gt;
      &lt;br /&gt;
    }&lt;br /&gt;
  }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Set auto increment, seed and step for primary key column==&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;
    class Program&lt;br /&gt;
    {&lt;br /&gt;
        static void Main(string[] args)&lt;br /&gt;
        {&lt;br /&gt;
            DataTable dt = new DataTable();&lt;br /&gt;
            DataColumn pkCol = dt.Columns.Add(&amp;quot;Id&amp;quot;, typeof(int));&lt;br /&gt;
            dt.Columns.Add(&amp;quot;Field1&amp;quot;, typeof(string)).MaxLength = 50;&lt;br /&gt;
            dt.PrimaryKey = new DataColumn[] {dt.Columns[&amp;quot;Id&amp;quot;]};&lt;br /&gt;
            pkCol.AutoIncrement = true;&lt;br /&gt;
            pkCol.AutoIncrementSeed = 100;&lt;br /&gt;
            pkCol.AutoIncrementStep = 10;&lt;br /&gt;
            for (int i = 1; i &amp;lt;= 5; i++)&lt;br /&gt;
                dt.Rows.Add(new object[] {null, &amp;quot;Value &amp;quot; + i });&lt;br /&gt;
            foreach (DataRow row in dt.Rows)&lt;br /&gt;
                Console.WriteLine(&amp;quot;Id = {0}\tField1 = {1}&amp;quot;,row[&amp;quot;Id&amp;quot;], row[&amp;quot;Field1&amp;quot;]);&lt;br /&gt;
        }&lt;br /&gt;
    }&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Use a relationship with a calculated column==&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 CalculatedColumn&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=Northwind;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
        string SQL = &amp;quot;SELECT * FROM Categories&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;Categories&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
        cmd.rumandText = &amp;quot;SELECT * FROM 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;
        ds.Tables[&amp;quot;Categories&amp;quot;].Columns.Add(&amp;quot;AveragePrice&amp;quot;, typeof(Decimal), &amp;quot;AVG(Child(Cat_Prod).UnitPrice)&amp;quot;);&lt;br /&gt;
        ds.Tables[&amp;quot;Categories&amp;quot;].Columns.Add(&amp;quot;TotalPrice&amp;quot;, typeof(Decimal), &amp;quot;SUM(Child(Cat_Prod).UnitPrice)&amp;quot;);&lt;br /&gt;
        foreach (DataRow row in ds.Tables[&amp;quot;Categories&amp;quot;].Rows)&lt;br /&gt;
        {&lt;br /&gt;
            Console.WriteLine(row[&amp;quot;CategoryName&amp;quot;]);&lt;br /&gt;
            Console.WriteLine(row[&amp;quot;AveragePrice&amp;quot;]);&lt;br /&gt;
            Console.WriteLine(row[&amp;quot;TotalPrice&amp;quot;]);&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>