c# - SqlDataAdapter.FillSchema() 方法不起作用

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

我做了以下事情:

SqlConnection conn = new SqlConnection("... my connection string ...");

dataAdapter = new SqlDataAdapter();

SqlCommand selectCommand = new SqlCommand("select * from items", conn);
dataAdapter.SelectCommand = selectCommand;

DataTable schemaTable = new DataTable();
dataAdapter.FillSchema(schemaTable, SchemaType.Source);

但是,schemaTable 中没有行。 dataAdapter.Fill() 工作。

最佳答案

我想你误解了什么FillSchema

它采用传入的数据表(没有行也没有列)并构建架构,添加列的大小、类型等信息...对应于 SelectCommand 将返回的表.
它不会用记录填充传入的表。

事实上,如果您在调用 FillSchema 后查看列数你会发现你的 schemaTable已经“构建”了与 items 匹配的列表。

那么,FillSchema 调用有什么用,考虑到 Fill 调用会用其列名和类型同样填充表?嗯,FillSchema用于为以下Fill准备传入的表具有一些不会被 Fill 调用加载的属性。例如,假设您的 items表有一个 AutoIncrement柱子。调用 Fill 后,此属性在匹配的 DataColumn 上不可用。但是,如果您传递给 Fill,即由 FillSchema 准备的表,则该属性可用。

如果您只想要有关表格列的信息,则需要不同的方法

using(SqlConnection con = new SqlConnection(.......)
{
    con.Open();
    DataTable schema = con.GetSchema("Columns", new string[] {null, null, "items"});
    foreach(DataRow row in schema.Rows)
        Console.WriteLine("TABLE:" + row.Field<string>("TABLE_NAME") + 
                          " COLUMN:" + row.Field<string>("COLUMN_NAME"));
}

或者以更标准的方式

using(SqlConnection con = new SqlConnection(.......)
{
    con.Open();
    DataTable dt = new DataTable();
    SqlCommand cmd = new SqlCommand(@"SELECT * FROM INFORMATION_SCHEMA.COLUMNS 
                                      WHERE TABLE_NAME='items' 
                                      AND TABLE_CATALOG = 'yourDBNameHere'", con);
    SqlDataReader reader = cmd.ExecuteReader();
    dt.Load(reader);
    foreach(DataRow row in dt.Rows)
      ..... catalog, name, ordinal_position, column_default etc....
}

关于c# - SqlDataAdapter.FillSchema() 方法不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27933645/

相关文章:

sql - 检查 SQL 中字符串是否包含重音字符?

c# - 测试方法 : async Task TestSth() does not work with . NET 4.0

c# - 如果条件为 nullable

c# - 公共(public)内部类

c# - app.config 中的设置何时实际读取?

c# - 观察新插入的 SQL 表的有效方法

c# - 在我的数据库中更改 FK 的级联行为时需要更新模型吗?

c# - 我的 C# 和 PHP 解密方法有何不同?

c# - .NET Core 单元测试未显示在 AppVeyor 测试窗口(和徽章)中

c# - 如何在 c#.net 中使用单个变量而不是使用多个变量