質問

SQLConnectionオブジェクトを指定すると、1つのテーブルのスキーマをどのように取得できますか?

先日これを試していましたが、クエリを実行して得たDataSetからスキーマを取得できるように見えましたが、接続から取得できるすべてのスキーマ情報は、テーブルの実際の詳細ではなく、テーブルが利用可能でした。

これを行う簡単な方法があると確信しています。

役に立ちましたか?

解決

クエリから(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以前の場合は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'
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top