Получение схемы для таблицы
-
05-07-2019 - |
Вопрос
Учитывая объект SqlConnection, как вы можете получить схему для одной таблицы?
Я пробовал это на днях, и мне показалось, что я смог получить схему из набора данных, который я получил в результате выполнения запроса, но вся информация о схеме, которую я мог получить из соединения, похоже, была связана с тем, какие таблицы были доступны, а не с фактическими деталями в таблицах.
Я уверен, что есть простой способ сделать это.
Решение
Я думаю, что доступ к схеме из запроса (через GetSchemaTable) - единственный способ сделать это. Вы можете запустить запрос, который не возвращает строк (выберите * из таблицы, где 1 = 2), если схема - это все, что вас интересует.
Вы должны использовать KeyInfo CommandBehaviour для выполнения исходного запроса, так как в противном случае не вся возвращаемая информация гарантированно будет точной
Command.ExecuteReader(CommandBehavior.KeyInfo)
Другие советы
Этот код будет делать то, что вы хотите (очевидно, изменить имя таблицы, имя сервера и т. д.):
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();
}
}
}
SQL Server - запрашивает представления каталога...системные объекты, системные столбцы и т.д., если 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'