获取表的架构

时间:2008-10-06 10:42:16

标签: c# sql sql-server ado.net schema

给定一个SQLConnection对象,如何获得单个表的模式?

前几天我正在尝试这个,我似乎能够从运行查询得到的DataSet中获取模式,但是我从连接中获得的所有模式信息似乎都与表格可用,而不是表格的实际细节。

我确信有一种简单的方法可以做到这一点。

3 个答案:

答案 0 :(得分:6)

此代码将执行您想要的操作(显然更改表名,服务器名称等):

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 :(得分:3)

我认为从查询中访问模式(通过GetSchemaTable)是唯一的方法。 如果架构是您感兴趣的,那么您可以运行不返回任何行的查询(从表中选择*,其中1 = 2)。

您应该使用KeyInfo CommandBehaviour来执行源查询,否则并非所有返回的信息都保证准确

Command.ExecuteReader(CommandBehavior.KeyInfo)

答案 2 :(得分:0)

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'