亲宝软件园·资讯

展开

C#利用泛型将DataSet转为Model C#实现利用泛型将DataSet转为Model的方法

罪恶的花生 人气:0
想了解C#实现利用泛型将DataSet转为Model的方法的相关内容吗,罪恶的花生在本文为您仔细讲解C#利用泛型将DataSet转为Model的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C#,泛型,DataSet,Model,下面大家一起来学习吧。

本文实例讲述了C#实现利用泛型将DataSet转为Model的方法。分享给大家供大家参考。具体如下:

因为网站需要用C#开发,习惯了java的泛型,所以看了一下C#下,也可以这样做,随便写了一个。

public static List<T> PutAllVal<T>(T entity, DataSet ds) where T : new() {
  List<T> lists = new List<T>();
  if (ds.Tables[0].Rows.Count > 0) {
    foreach (DataRow row in ds.Tables[0].Rows) {
      lists.Add(PutVal(new T(),row));
    }
  }
  return lists;
}
public static T PutVal<T>(T entity, DataRow row) where T : new() {
  //初始化 如果为null
  if (entity == null){
    entity = new T();
  }
  //得到类型
  Type type = typeof(T);
  //取得属性集合
  PropertyInfo[] pi = type.GetProperties();
  foreach (PropertyInfo item in pi){
    //给属性赋值
    if (row[item.Name] != null && row[item.Name] != DBNull.Value) {
      if (item.PropertyType == typeof(System.Nullable<System.DateTime>)) {
        item.SetValue(entity, Convert.ToDateTime(row[item.Name].ToString()), null);
      } else {
        item.SetValue(entity, Convert.ChangeType(row[item.Name], item.PropertyType), null);
      }
    }
  }
  return entity;
}

希望本文所述对大家的C#程序设计有所帮助。

加载全部内容

相关教程
猜你喜欢
用户评论