-
ASP.NET:通过反射填充泛型集合List的静态方法
- 如何通过反射,从DataReader将数据填充到数据实体泛型集合的静态方法.
-
- //Kchen.Core.BaseBusinessObject为通用数据实体类,此处仅为限定T所继承的类型
public static IList<T> FillDataListGeneric<T>(System.Data.IDataReader reader) where T : Kchen.Core.BaseBusinessObject
{
//实例化一个List<>泛型集合
IList<T> DataList = new List<T>();
while (reader.Read())
{
//由于是是未知的类型,所以必须通过Activator.CreateInstance<T>()方法来依据T的类型动态创建数据实体对象
T RowInstance = Activator.CreateInstance<T>();
//通过反射取得对象所有的Property
foreach (PropertyInfo Property in typeof(T).GetProperties())
{
//BindingFieldAttribute为自定义的Attribute,用于与数据库字段进行绑定
foreach (BindingFieldAttribute FieldAttr in Property.GetCustomAttributes(typeof(BindingFieldAttribute), true))
{
try
{
//取得当前数据库字段的顺序
int Ordinal = reader.GetOrdinal(FieldAttr.FieldName);
if (reader.GetValue(Ordinal) != DBNull.Value)
{
//将DataReader读取出来的数据填充到对象实体的属性里
Property.SetValue(RowInstance, Convert.ChangeType(reader.GetValue(Ordinal), Property.PropertyType), null);
}
}
catch
{
break;
}
}
}
//将数据实体对象add到泛型集合中
DataList.Add(RowInstance);
}
return DataList;
}
调用的时候使用如下代码
- //伪代码 OleDbDataReader _ds = 创建一个OleDbDataReader
IList<Product> _result = Kchen.Utilities.FillDataListGeneric<Product>(_ds);
- 此静态方法通过一个实体类型和DateReader,快速的将数据填充到数据实体泛型集合中.
-
相关阅读:
C# 文件流
SQL语句(十八_补充)——存储过程
SQL语句(十九)——存储过程(练习)
SQL语句(十八)—— 存储过程
软件测试(二)PICT的使用 组合测试方法(两两组合测试,可遍历组合测试)
Swing布局管理器
软件测试(一)-黑盒测试 随机测试技巧
(一)在Lingo中使用集合
数学建模 TSP(旅行商问题) Lingo求解
哲学家进餐问题
-
原文地址:https://www.cnblogs.com/HondaHsu/p/734935.html
Copyright © 2020-2023
润新知