DataTable转任意类型对象List数组-----工具通用类(利用反射和泛型)
2014-12-10 20:26
441 查看
public class ConvertHelper<T> where T : new() { /// <summary> /// 利用反射和泛型 /// </summary> /// <param name="dt"></param> /// <returns></returns> public static List<T> ConvertToList(DataTable dt) { // 定义集合 List<T> ts = new List<T>(); // 获得此模型的类型 Type type = typeof(T); //定义一个临时变量 string tempName = string.Empty; //遍历DataTable中所有的数据行 foreach (DataRow dr in dt.Rows) { T t = new T(); // 获得此模型的公共属性 PropertyInfo[] propertys = t.GetType().GetProperties(); //遍历该对象的所有属性 foreach (PropertyInfo pi in propertys) { tempName = pi.Name;//将属性名称赋值给临时变量 //检查DataTable是否包含此列(列名==对象的属性名) if (dt.Columns.Contains(tempName)) { // 判断此属性是否有Setter if (!pi.CanWrite) continue;//该属性不可写,直接跳出 //取值 object value = dr[tempName]; //如果非空,则赋给对象的属性 if (value != DBNull.Value) pi.SetValue(t, value, null); } } //对象添加到泛型集合中 ts.Add(t); } return ts; } } 调用方法: List<ConfigRedisModel> lists = ConvertHelper<ConfigRedisModel>.ConvertToList(table); //说明:1、参数table即是从数据库读出来的DataTable // 2、ConfigRedisModel:任意自定义对象,但此对象一定和参数table一致(对象属性和数据库中的table字段匹配一样)
相关文章推荐
- Java -- 利用反射 操作任意数组,包括对象数组 和 基本数据类型的数组
- 通过反射获取泛型参数数组(Class对象 List类型)
- Java -- 利用反射 操作任意数组,包括对象数组 和 基本数据类型的数组
- 数组反射,判断Class 对象是否为数组及类型。将任意类型数组的大小加倍
- 黑马程序员--Java基础加强--15.利用反射操作泛型IV【通过反射Method解析泛型方法思路】【通过Method对四种Type子接口类型进行解剖】【使用递归对任意复合泛型类型进行彻底解剖】【个人
- C#中利用LINQ to XML与反射把任意类型的泛型集合转换成XML格式字符串的方法
- Java利用反射向集合(List或Map)中存入任意类型的数据(绕过编译阶段)
- 利用反射实现mysql数据库sql查询 返回List<E>泛型(持久化)对象
- 程序清单-利用反射扩展任意类型的数组
- 利用反射和泛型把Model对象按行储存进数据库以及按行取出然后转换成Model 类实例 MVC网站通用配置项管理
- C#中利用LINQ to XML与反射把任意类型的泛型集合转换成XML格式字符串的方法
- 利用泛型和反射编写通用基础类型转换方法
- 将任意一个对象中的所有String类型 的成员变量所对应字符串中的“b”改成“a”(利用反射)
- 01-java基础加强,eclipse工具使用,快捷键,断点调试,单元测试,jdk5新特性,增强for循环,集合map,list,可变参数,枚举,反射,泛型
- 将任意类型数组中的所有元素填充为相应类型的对象(题目很长,其实代码很短)
- C# 泛型 与 反射 实现 任意类型间的类型转换
- 利用反射把DataTable自动赋值到Model实体(自动识别数据类型)
- 把传过来的Object对象转换成Collection类型的对象。isArray()方法,判定此Class对象是否表示一个数组类。java.lang.reflect.Array 对任意数组进行操作
- 使用泛型, 写一个为任意类型的动态数组添加元素的方法
- 数组反射,判断Class 对象是否为数组及类型。将任意类型数组的大小加倍 .