Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

Получаване на схемата за таблица

Този код ще направи това, което искате (очевидно ще промени името на таблицата, името на сървъра и т.н.):

using System;
using System.Collections.Generic;
using System.Text;

using System.Data;
using System.Data.SqlClient;
using System.Data.SqlTypes;

namespace ConsoleApp
{
    class Program
    {
        static void Main(string[] args)
        {
            string query = "SELECT * FROM t where 1=0";
            string connectionString = "initial catalog=test;data source=localhost;Trusted_Connection=Yes";

            DataTable tblSchema;

            using (SqlConnection cnn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = cnn.CreateCommand())
                {
                    cmd.CommandText = query;
                    cmd.CommandType = CommandType.Text;
                    cnn.Open();
                    using (SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.KeyInfo))
                    {
                        tblSchema = rdr.GetSchemaTable();
                    }
                    cnn.Close();
                }
            }
            int numColumns = tblSchema.Columns.Count;
            foreach (DataRow dr in tblSchema.Rows)
            {
                Console.WriteLine("{0}: {1}", dr["ColumnName"], dr["DataType"]);
            }

            Console.ReadLine();
        }
    }
}


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Функция в SQL Server 2008, подобна на НАЙ-ГОЛЯМАТА в mysql?

  2. Промяна на функция с таблично значение в SQL Server

  3. Таблица с данни, съдържаща SqlGeometry, причинява неуспешно изпълнение на съхранена процедура... Защо?

  4. SQL Server отчита броя на отделните стойности във всяка колона на таблица

  5. Как да заредя XML файл в база данни с помощта на SSIS пакет?