SQLConnection オブジェクトが与えられた場合、単一のテーブルのスキーマを取得するにはどうすればよいでしょうか?
先日これを試していて、クエリを実行して取得した DataSet からスキーマを取得できるように見えましたが、接続から取得できるすべてのスキーマ情報は、利用可能なテーブルに関連しているように見えましたテーブルの実際の詳細ではありません。
これを行う簡単な方法があると確信しています。
SQLConnection オブジェクトが与えられた場合、単一のテーブルのスキーマを取得するにはどうすればよいでしょうか?
先日これを試していて、クエリを実行して取得した DataSet からスキーマを取得できるように見えましたが、接続から取得できるすべてのスキーマ情報は、利用可能なテーブルに関連しているように見えましたテーブルの実際の詳細ではありません。
これを行う簡単な方法があると確信しています。
このコードはあなたが望むことをします(明らかにテーブル名、サーバー名などを変更します):
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();
}
}
}
クエリから (GetSchemaTable を介して) スキーマにアクセスすることが唯一の方法だと思います。スキーマだけに関心がある場合は、行を返さないクエリを実行できます (select * from table where 1=2)。
KeyInfo CommandBehaviour を使用してソース クエリを実行する必要があります。そうしないと、返されるすべての情報が正確であることが保証されないためです。
Command.ExecuteReader(CommandBehavior.KeyInfo)
SQL Server - カタログ ビューを照会します... SQL 2000 以前の場合は sysobjects、syscolumns など... SQL 2005 以降の場合は sys.objects、sys.columns など。(古いビューは引き続き使用できますが、新しいビューを使用することをお勧めします)
ここで完全なリファレンス: 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'