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();
           }
       }
     
  • 相关阅读:
    java-多个数的和
    大道至简第二章
    大道至简第一章感悟上
    Tools
    LruCache
    Fragment
    科普指纹识别
    Python使用MySQL数据库
    Eclipse中添加PyDev插件
    UniversalAndroidImageLoader出现异常:ImageLoader: Unable to resolve host "https": No address associated with host
  • 原文地址:https://www.cnblogs.com/dinggf/p/11654111.html
Copyright © 2011-2022 走看看