首页 > 代码库 > DataTable转任意类型对象List数组-----工具通用类(利用反射和泛型)

DataTable转任意类型对象List数组-----工具通用类(利用反射和泛型)

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 =http://www.mamicode.com/ 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字段匹配一样)

 

DataTable转任意类型对象List数组-----工具通用类(利用反射和泛型)