Получение схемы для таблицы

Учитывая объект SQLConnection, как вы можете получить схему для одной таблицы?

Я пробовал это на днях, и, похоже, мне удалось получить схему из набора данных, который я получил при выполнении запроса, но вся информация о схеме, которую я мог получить из соединения, похоже, была связана с тем, какие таблицы были доступны а не фактические детали на таблицах.

Я уверен, что есть простой способ сделать это.


person Omar Kooheji    schedule 06.10.2008    source источник
comment
См. также: stackoverflow.com/q/4155993   -  person Factor Mystic    schedule 11.11.2010


Ответы (3)


Я думаю, что доступ к схеме из запроса (через GetSchemaTable) - единственный способ сделать это. Вы можете запустить запрос, который не возвращает строк (выберите * из таблицы, где 1 = 2), если схема — это все, что вас интересует.

Вы должны использовать KeyInfo CommandBehaviour для выполнения исходного запроса, так как в противном случае не вся возвращаемая информация будет точной.

Command.ExecuteReader(CommandBehavior.KeyInfo)
person Community    schedule 06.10.2008

Этот код будет делать то, что вы хотите (очевидно, изменить имя таблицы, имя сервера и т. д.):

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();
        }
    }
}
person Mitch Wheat    schedule 06.10.2008

SQL Server - запрашивать представления каталога... sysobjects, syscolumns и т. д., если SQL 2000 или более ранняя версия... sys.objects, sys.columns и т. д., если SQL 2005 или выше. (хотя старые представления все еще доступны, рекомендуется использовать более новые)

Полная ссылка здесь: http://msdn.microsoft.com/en-us/library/ms189783.aspx

Пример:

select so.name, sc.*
from sys.objects as so
inner join sys.columns as sc on sc.object_id = so.object_id
where so.name='some_table'
person KristoferA    schedule 06.10.2008
comment
Что мы можем сделать для запросов, а не только для таблиц? например. SELECT * FROM Table1 INNER JOIN Table2... - person CSharper; 12.09.2009