IDataReader转换成list通用方法
2014-10-15 11:07
162 查看
public static IList<T> ReaderToList<T>(this IDataReader dr) { //DateTime dt = DateTime.Now; using (dr) { List<T> list = new List<T>(); Type modelType = typeof(T); int count = dr.FieldCount; while (dr.Read()) { T model = Activator.CreateInstance<T>(); for (int i = 0; i < count; i++) { if (!IsNullOrDBNull(dr[i])) {//GetPropertyName PropertyInfo pi = modelType.GetProperty(dr.GetName(i), BindingFlags.GetProperty | BindingFlags.Public | BindingFlags.Instance | BindingFlags.IgnoreCase); if (pi != null) { pi.SetValue(model, HackType(dr[i], pi.PropertyType), null); // pi.SetValue(model, Convert.ChangeType(dr[i], pi.PropertyType), null); } } } list.Add(model); } // DateTime dt2 = DateTime.Now; // Logger logInfo = NLog.LogManager.GetLogger("filter"); // logInfo.Info("List:" + (dt2 - dt).TotalSeconds); return list; } }
View Code
相关文章推荐
- DataTable转换为List<Model>的通用方法
- java 将list转换为map 的泛型通用方法
- ASP.NET.MVC--注解和反射将Enum转换List<SelectListItem>为@Html.DropDownListFor()下拉列表的通用方法
- 关于数组和List之间相互转换的方法
- LINQ Expressions 动态生成委托——DataReader转换为List方法改进
- 关于数组和List之间相互转换的方法
- 利用反射把让Model与XML互相转换的方法,很通用
- 快速排序List的通用方法
- java对世界各个时区(TimeZone)的通用转换处理方法
- dataset数据转换成json的格式通用方法
- 数组和List之间相互转换的方法
- int和integer互相转换的方法+List 转换为Vector 的方法~老忘记~~
- IDataReader 转换成DataTable
- List 转换 DataTable DataSet的方法
- ADO.NET ASP.NET 将 SQLDatareader 转换成 List
- 通用创建对象(建立IdataReader与Class关系,同时将IdataReader数据赋给Class对象(原创)
- 利用反射把让Model与XML互相转换的方法,很通用
- 通用类型转换方法
- [java]关于数组和List之间相互转换的方法
- java中数组与List相互转换的方法