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();
           }
       }
     
  • 相关阅读:
    投票通过,PHP 8 确认引入 Union Types 2.0
    Laravel 菜鸟的晋级之路
    给公司写的composer包开发的规范
    Swoft 源码剖析
    听说PHP的生成器yield处理大量数据杠杠的
    读懂JWT的使用,你就会用PHP如何实现了
    python标准库及其它应用
    python常用算法题
    python迭代器实例
    python生成器实例
  • 原文地址:https://www.cnblogs.com/dinggf/p/11654111.html
Copyright © 2011-2022 走看看