gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 13:45:39 26 4
gpt4 key购买 nike

我做了以下事情:

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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com