zoukankan      html  css  js  c++  java
  • DataTable转List,DataTable转为Model对象帮助类

    DataTable转List,DataTable转为Model对象帮助类

    public class ModelConvertHelper<T> where T : new()
       {
           public static List<T> ConvertToModel(DataTable dt)
           {
               // 定义集合    
               List<T> ts = new List<T>();
               // 获得此模型的类型   
               Type type = typeof(T);
               string tempName = "";
               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;
           }
           public static T ConvertToInfo(DataTable dt)
           {
               // 定义集合    
               T ts = new T();
               // 获得此模型的类型   
               Type type = typeof(T);
               string tempName = "";
               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);
                       }
                   }
                   return t;
               }
               return new T();
           }
       }
     
  • 相关阅读:
    javascript创建对象的方法--基本模式
    javascript进阶课程--第二章--对象
    JavaScript中的global对象,window对象以及document对象的区别和联系
    onblur 对象失去焦点事件
    php排序
    php数组插入数据
    thinkphp多层volist实现多表查询
    数据转换
    循环赛日程安排问题
    JS中setTimeout()的使用方法具体解释
  • 原文地址:https://www.cnblogs.com/dinggf/p/11654111.html
Copyright © 2011-2022 走看看