获取表的架构
给定一个SQLConnection对象,如何获得单个表的模式?
前几天我正在尝试这个,我似乎能够从运行查询得到的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 – 查询目录视图… 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'