技术文章 > 利用泛型将DataSet转为Model

利用泛型将DataSet转为Model

2017-11-19 07:27

文档管理软件,文档管理系统,知识管理系统,档案管理系统的技术资料:
利用泛型将DataSet转为Model
罪恶的花生 发布于 2014年11月16日 23时
http://www.oschina.net/code/snippet_54124_43931
因为网站需要用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;
}