泛型的运用(用于查询数据后DataTable转实体类)
2019.8.14 更新
补全了DataTable转泛型集合的方法:
/// <summary>
/// DataTable转实体类集合
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dt">DataTable数据集</param>
public static List<T> SetValueForListByData<T>(DataTable dt) where T : new()
{
List<T> List = new List<T>();
foreach (DataRow dr in dt.Rows)
{
T Entity = new T();
//这里是昨天就发在随笔里的方法,下翻就能看到,
SetValueForEntityByData(Entity, dr);
//下面一段是完整的赋值流程,与上面调用的方法二取一即可。
//PropertyInfo[] propertyInfo = Entity.GetType().GetProperties();
//Type type = Entity.GetType();
//foreach (PropertyInfo item in propertyInfo)
//{
// item.SetValue(Entity, Convert.ChangeType(dr[item.Name], item.PropertyType));
//}
List.Add(Entity);
}
return List;
}
在循环DataTable中的每一行时调用该方法,可避免实体类属性众多时手动赋值的麻烦。
1.有返回值版本,该版本需要注意的是,普通情况下的泛型没有构造器,无法直接通过new关键字实例化,所以需要在方法签名后面加上 where T : new(),为方法内的所有泛型变量添加一个空构造器,使之可以实例化。它最终的效果是实例化实体类并且赋值,然后return赋值结果。
public static T SetValueForEntityByData<T>(DataRow dr) where T : new()
{
T Entity = new T();
PropertyInfo[] propertyInfo = Entity.GetType().GetProperties();
Type type = Entity.GetType();
foreach (PropertyInfo item in propertyInfo)
{
item.SetValue(Entity, Convert.ChangeType(dr[item.Name], item.PropertyType));
}
return Entity;
}
2.无返回值版本,不用担心泛型的实例化,省略where,但是需要能理解引用类型与值类型在内存上的储存方式的区别。它最终的效果是为传入的实体类赋值,并且赋值结果不用经过return便可以体现。
public static void SetValueForEntityByData<T>(T Entity,DataRow dr)
{
Type type = typeof(T);
PropertyInfo[] propertyInfo = Entity.GetType().GetProperties();
foreach (PropertyInfo item in propertyInfo)
{
item.SetValue(Entity, Convert.ChangeType(dr[item.Name], item.PropertyType));
}
}
最新文章
- 挑子学习笔记:特征选择——基于假设检验的Filter方法
- Markdown基本语法
- Makefile笔记之一 ------ 变量的引用及赋值
- [转]非常实用的15款开源PHP类库
- Linux &; Oracle 安装目录说明
- php课程---建立一个简单的下拉列表框
- Oracle 10g ORA-01034: ORACLE not available 错误
- 添加Pods后,import无提示的解决办法
- 安装orcle10g oel5.6
- Hadoop-1.1.2、HBase-0.94.7完全分布式集群结构
- 国内ng学习网站
- 【java图形计算器】 java awt swing组件应用
- 【Beta】 第六次Daily Scrum Meeting
- ASP.NET部分代码示例
- [manjaro]换源到中国并按照速度排序
- Clustering[Introduction]
- 【转】fiddler抓包HTTPS请求
- js高级---本地对象、内置对象、宿主对象
- IO流中File文件最常用和直接的用法
- python标准库介绍——27 random 模块详解