上图是在VS中的调试模式中,可以看到
根据上图我们大概可以猜测一下DataTable内部的数据结构,或者C#让我们理解的结构是什么。
其中DataColumn对应着图中列,ColumnName就是图 所示的列名。而DataRow就是行,ItemArray则是一行行数据。
这样一来,显然就比直接使用IDataReader访问数据要方便很多。
依据上例:
我们试着获取一下第三行的Province列值,如果觉得这个表述别扭的话,看一下我的写法,就知道我为什么这么表示了。
var table = set.Tables[0];// 先拿到第一个表 var value = table.Rows[2]["Province"];这是一种蚂蚁搬家式的读取数据方式。C#为DataTable提供了一个扩展方法:
public static EnumerableRowCollection<DataRow> AsEnumerable(this DataTable source);将表格转换成可枚举的DataRow集合。
所以我们可以用foreach循环来遍历DataTable。
3. 未完待续在这一节简单介绍了一下ADO.NET的离线查询支持。当我们能从数据库中获取到DataTable的时候,我们就能通过这个做出更多的事情来。下一章我将带领大家结合之前介绍的反射,实现一个简单的ORM工具类。
更多内容烦请关注我的博客《高先生小屋》