作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我做了以下事情:
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/
我做了以下事情: SqlConnection conn = new SqlConnection("... my connection string ..."); dataAdapter = new S
我是一名优秀的程序员,十分优秀!