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

	<entry>
		<id>http://www.nfex.ru/index.php?title=Csharp/C_Sharp/Database_ADO.net/Table_Schema&amp;diff=1011&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/Table_Schema&amp;diff=1011&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/Table_Schema&amp;diff=1012&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/Table_Schema&amp;diff=1012&amp;oldid=prev"/>
				<updated>2010-05-26T11:42:43Z</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;==Get all table names==&lt;br /&gt;
&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.OleDb;&lt;br /&gt;
public class DatabaseInfo {    &lt;br /&gt;
 public static void Main () { &lt;br /&gt;
   String connect = &amp;quot;Provider=Microsoft.JET.OLEDB.4.0;data source=.\\Employee.mdb&amp;quot;;&lt;br /&gt;
   OleDbConnection con = new OleDbConnection(connect);&lt;br /&gt;
   con.Open();  &lt;br /&gt;
   Console.WriteLine(&amp;quot;Made the connection to the database&amp;quot;);&lt;br /&gt;
   Console.WriteLine(&amp;quot;Information for each table contains:&amp;quot;);&lt;br /&gt;
   DataTable tables = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,new object[]{null,null,null,&amp;quot;TABLE&amp;quot;});&lt;br /&gt;
   Console.WriteLine(&amp;quot;The tables are:&amp;quot;);&lt;br /&gt;
   foreach(DataRow row in tables.Rows) &lt;br /&gt;
     Console.Write(&amp;quot;  {0}&amp;quot;, row[2]);&lt;br /&gt;
&lt;br /&gt;
   con.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;
==Get Column data type and name from DataColumn==&lt;br /&gt;
&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.OleDb;&lt;br /&gt;
public class DatabaseInfo {    &lt;br /&gt;
 public static void Main () { &lt;br /&gt;
   String connect = &amp;quot;Provider=Microsoft.JET.OLEDB.4.0;data source=.\\Employee.mdb&amp;quot;;&lt;br /&gt;
   OleDbConnection con = new OleDbConnection(connect);&lt;br /&gt;
   con.Open();  &lt;br /&gt;
   Console.WriteLine(&amp;quot;Made the connection to the database&amp;quot;);&lt;br /&gt;
   String cmd = &amp;quot;SELECT * FROM Employee&amp;quot;; &lt;br /&gt;
   OleDbDataAdapter adapter = new OleDbDataAdapter();&lt;br /&gt;
   adapter.SelectCommand = new OleDbCommand(cmd, con);&lt;br /&gt;
   DataSet ds = new DataSet();&lt;br /&gt;
   adapter.Fill(ds, &amp;quot;Employee&amp;quot;);&lt;br /&gt;
   DataTable item = ds.Tables[0];&lt;br /&gt;
   Console.WriteLine(&amp;quot;Table name: {0}&amp;quot;, item.TableName);&lt;br /&gt;
   Console.WriteLine(&amp;quot;Its columns are:&amp;quot;);&lt;br /&gt;
   foreach (DataColumn col in item.Columns)&lt;br /&gt;
     Console.WriteLine(&amp;quot;{0}\t{1}&amp;quot;, col.ColumnName, col.DataType);&lt;br /&gt;
   con.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;
==Get specified column data type and column name from OleDbSchemaTable==&lt;br /&gt;
&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.OleDb;&lt;br /&gt;
public class DatabaseInfo {    &lt;br /&gt;
 public static void Main () { &lt;br /&gt;
   String connect = &amp;quot;Provider=Microsoft.JET.OLEDB.4.0;data source=.\\Employee.mdb&amp;quot;;&lt;br /&gt;
   OleDbConnection con = new OleDbConnection(connect);&lt;br /&gt;
   con.Open();  &lt;br /&gt;
   Console.WriteLine(&amp;quot;Made the connection to the database&amp;quot;);&lt;br /&gt;
   Console.WriteLine(&amp;quot;Information for each table contains:&amp;quot;);&lt;br /&gt;
   DataTable tables = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,new object[]{null,null,null,&amp;quot;TABLE&amp;quot;});&lt;br /&gt;
   DataTable cols = con.GetOleDbSchemaTable(OleDbSchemaGuid.Columns,&lt;br /&gt;
         new object[]{null,null,&amp;quot;Employee&amp;quot;,null});&lt;br /&gt;
   Console.WriteLine(&amp;quot;The columns in the Customer table are:&amp;quot;);&lt;br /&gt;
 &lt;br /&gt;
   foreach(DataRow row in cols.Rows) &lt;br /&gt;
     Console.WriteLine(&amp;quot;  {0}\t{1}&amp;quot;, row[3],(OleDbType)row[11]);&lt;br /&gt;
   con.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;
==Get table Schema==&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 SchemaTable&lt;br /&gt;
   {&lt;br /&gt;
      static void Main(string[] args)&lt;br /&gt;
      {&lt;br /&gt;
         string connString = &amp;quot;server=(local)\\SQLEXPRESS;database=MyDatabase;Integrated Security=SSPI&amp;quot;;&lt;br /&gt;
         string sql = @&amp;quot;select * from employee&amp;quot;;&lt;br /&gt;
         SqlConnection conn = new SqlConnection(connString);&lt;br /&gt;
         try {&lt;br /&gt;
            conn.Open();&lt;br /&gt;
            SqlCommand cmd = new SqlCommand(sql, conn);&lt;br /&gt;
            SqlDataReader reader = cmd.ExecuteReader();&lt;br /&gt;
            DataTable schema = reader.GetSchemaTable();&lt;br /&gt;
            foreach (DataRow row in schema.Rows)&lt;br /&gt;
            { &lt;br /&gt;
               foreach (DataColumn col in schema.Columns){&lt;br /&gt;
                  Console.WriteLine(col.ColumnName + &amp;quot; = &amp;quot; + row[col]);&lt;br /&gt;
                  Console.WriteLine(&amp;quot;Null value allowed: &amp;quot; + col.AllowDBNull);&lt;br /&gt;
               }&lt;br /&gt;
            }&lt;br /&gt;
            reader.Close();&lt;br /&gt;
         } catch(Exception e) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;Error Occurred: &amp;quot; + e);&lt;br /&gt;
         } finally {&lt;br /&gt;
            conn.Close();&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;
==How to read a table schema==&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 SchemaOnlyCommandBehavior&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 =&amp;quot;SELECT ID, FirstName, LastName FROM Employee WHERE ID = 8&amp;quot;;&lt;br /&gt;
    mySqlConnection.Open();&lt;br /&gt;
    SqlDataReader productsSqlDataReader =mySqlCommand.ExecuteReader(CommandBehavior.SchemaOnly);&lt;br /&gt;
    DataTable myDataTable = productsSqlDataReader.GetSchemaTable();&lt;br /&gt;
    foreach (DataRow myDataRow in myDataTable.Rows)&lt;br /&gt;
    {&lt;br /&gt;
      Console.WriteLine(&amp;quot;\nNew column details follow:&amp;quot;);&lt;br /&gt;
      foreach (DataColumn myDataColumn in myDataTable.Columns)&lt;br /&gt;
      {&lt;br /&gt;
        Console.WriteLine(myDataColumn + &amp;quot;= &amp;quot; +&lt;br /&gt;
          myDataRow[myDataColumn]);&lt;br /&gt;
        if (myDataColumn.ToString() == &amp;quot;ProviderType&amp;quot;)&lt;br /&gt;
        {&lt;br /&gt;
          Console.WriteLine(myDataColumn + &amp;quot;= &amp;quot; +&lt;br /&gt;
            ((System.Data.SqlDbType) myDataRow[myDataColumn]));&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    productsSqlDataReader.Close();&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;
==Read schema information using the FillSchema() method of a DataAdapter object==&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 FillSchema&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 ProductID, ProductName &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM Products;&amp;quot; +&lt;br /&gt;
      &amp;quot;SELECT OrderID &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM Orders;&amp;quot; +&lt;br /&gt;
      &amp;quot;SELECT OrderID, ProductID, UnitPrice &amp;quot; +&lt;br /&gt;
      &amp;quot;FROM [Order Details];&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.FillSchema(myDataSet, SchemaType.Mapped);&lt;br /&gt;
    mySqlConnection.Close();&lt;br /&gt;
    myDataSet.Tables[&amp;quot;Table&amp;quot;].TableName = &amp;quot;Products&amp;quot;;&lt;br /&gt;
    myDataSet.Tables[&amp;quot;Table1&amp;quot;].TableName = &amp;quot;Orders&amp;quot;;&lt;br /&gt;
    myDataSet.Tables[&amp;quot;Table2&amp;quot;].TableName = &amp;quot;Order Details&amp;quot;;&lt;br /&gt;
    foreach (DataTable myDataTable in myDataSet.Tables)&lt;br /&gt;
    {&lt;br /&gt;
      Console.WriteLine(&amp;quot;\n\nReading from the &amp;quot; +&lt;br /&gt;
        myDataTable + &amp;quot;DataTable:\n&amp;quot;);&lt;br /&gt;
      foreach (DataColumn myPrimaryKey in myDataTable.PrimaryKey)&lt;br /&gt;
      {&lt;br /&gt;
        Console.WriteLine(&amp;quot;myPrimaryKey = &amp;quot; + myPrimaryKey);&lt;br /&gt;
      }&lt;br /&gt;
      foreach (Constraint myConstraint in myDataTable.Constraints)&lt;br /&gt;
      {&lt;br /&gt;
        Console.WriteLine(&amp;quot;myConstraint.IsPrimaryKey = &amp;quot; + ((UniqueConstraint) myConstraint).IsPrimaryKey);&lt;br /&gt;
        foreach (DataColumn myDataColumn in ((UniqueConstraint) myConstraint).Columns)&lt;br /&gt;
        {&lt;br /&gt;
          Console.WriteLine(&amp;quot;myDataColumn.ColumnName = &amp;quot; + myDataColumn.ColumnName);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
      foreach (DataColumn myDataColumn in myDataTable.Columns)&lt;br /&gt;
      {&lt;br /&gt;
        Console.WriteLine(&amp;quot;\nmyDataColumn.ColumnName = &amp;quot; + myDataColumn.ColumnName);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.DataType = &amp;quot; + myDataColumn.DataType);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.AllowDBNull = &amp;quot; + myDataColumn.AllowDBNull);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.AutoIncrement = &amp;quot; + myDataColumn.AutoIncrement);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.AutoIncrementSeed = &amp;quot; + myDataColumn.AutoIncrementSeed);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.AutoIncrementStep = &amp;quot; + myDataColumn.AutoIncrementStep);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.MaxLength = &amp;quot; + myDataColumn.MaxLength);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.ReadOnly = &amp;quot; + myDataColumn.ReadOnly);&lt;br /&gt;
        Console.WriteLine(&amp;quot;myDataColumn.Unique = &amp;quot; + myDataColumn.Unique);&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>