
DataSet到List的泛型转换方法:自动类型适配

本文档介绍了如何将DataSet对象转换为List<T>类型的通用方法,适用于不同类型的字段自动类型转换。首先,该方法`ChangeDataSet<T>(DataSet ds, string tableName)`接收两个参数:一个DataSet对象`ds`和一个指定的表名`tableName`。其目的是在DataSet中的指定表格(DataTable)数据的基础上,创建一个动态类型的List<T>列表。
1. **方法输入与验证**:
方法首先检查传入的DataTable是否存在于DataSet中,如果不存在则返回null。确保传入的参数有效是转换操作的前提。
2. **数据获取**:
对于指定的DataTable,将其存储在`DataTabledt`变量中,以便后续遍历处理。
3. **创建List<T>对象**:
创建一个空的List<T>实例,`List<T> list = new List<T>()`,用于存储转换后的数据。
4. **遍历DataTable行和列**:
使用`foreach`循环遍历DataTable的每一行(DataRow)和列(DataColumn)。对于每一行的每一个单元格,通过反射获取属性(PropertyInfo)。
5. **类型转换**:
根据属性的类型执行适当的转换。常见的类型包括字符串(String)、整型(Int32、Int64)、布尔型(Boolean)、日期时间(DateTime)以及枚举类型(De)。这里通过`Convert`类的方法进行转换,确保从DbNull.Value值(表示空值)转换为正确的数据类型。
6. **填充模型对象**:
使用`Activator.CreateInstance<T>()`动态创建一个新的T类型对象,然后根据属性设置值,填充到模型实例`model`中。
7. **添加到List<T>**:
在完成单个模型对象的填充后,将其添加到List<T>中,以便最终返回整个列表。
8. **返回转换结果**:
当所有数据处理完成后,返回包含转换后的数据的List<T>。
总结来说,此方法提供了一种便捷的方式来处理DataSet与List之间的数据转换,尤其是当DataSet中的列类型多样时,可以自动适应并正确地将数据映射到目标类型的List中。这对于处理数据库查询结果或者需要进行进一步处理的DataSet数据非常实用。
相关推荐








huaix黑夜
- 粉丝: 2
最新资源
- C++/DirectDraw开发基础小游戏BattleCity教程
- 用SDL库开发Linux游戏的初学者指南
- 个人财务管理系统源码:简化版入门学习指南
- PCA人脸识别算法的Matlab实现
- 软件设计师核心知识系列讲座全面解析
- JSP购物车功能实现指南
- Windows窗口游戏框架开发与扩展指南
- 计费王计费系统下载分享与安装教程
- ERP软件用左树菜单图标优化用户界面
- ASP.NET免费分页控件发布:DLL与实用文档
- VFP API实用调用技巧及实例解析
- 探索Turbo C工具的现代应用与魅力
- C#与SQL打造高效图书馆管理系统解决方案
- ASP实现数据库驱动的级联菜单功能
- 用友870数据字典的access版介绍与应用
- Java基础小程序及测试答案解析
- 深入探索Rmi Callback机制与实例演示
- PowerBuilder PB通用工具条优化与图标状态管理
- MATLAB混沌计算工具箱:时间序列分析与预测
- grub4dos 0.43:打造完美U盘多重系统引导工具
- CVSNT v2.5.03.2382 Windows服务器端安装指南
- 试题库系统设计实现演示与题库管理系统
- J2SE 1.5 Java晋级经典教程解析
- Tomcat插件TomcatPluginV32Beta3详细解析