时间:2021-05-20
前段时间做了一个练手的小项目,名叫Book_Bar,用来卖书的,采用的是三层架构,也就是Models,IDAL,DAL,BLL 和 Web , 在DAL层中各个类中有一个方法比较常用,那就是RowToClass ,顾名思义,也就是将DataTable 中的数据封装到Models 中。结果导致在DAL各个类中写了很多类似的方法,后来就直接把它抽取出来做成了DataTable和DataRow的扩展方法,下面是代码:
using System;using System.Collections.Generic;using System.Data;using System.Reflection;namespace DAL{ /// <summary> /// 用于给 DataTable和 DataRow扩展方法 /// </summary> public static class TableExtensionMethod { /// <summary> /// 功能: /// 给DataTable扩展了一个方法,能够将DataTable中的行转变为对应的class对象,并封装到List集合中; /// </summary> /// <typeparam name="T">需要转变成为的class类型</typeparam> /// <param name="table">传入的DataTable对象</param> /// <returns>返回一个封装了对应class的List集合</returns> public static List<T> TableToClass<T>(this DataTable table) { Type type = typeof(T); PropertyInfo[] propArr = type.GetProperties();//获取所有属性 List<T> list = new List<T>(); DataRowCollection rows = table.Rows; int len = rows[0].ItemArray.Length;//获取第一行的列数,即class的属性个数 for (int i = 0; i < rows.Count; i++) { T t = (T)Activator.CreateInstance(type); for (int j = 0; j < len; j++)//这里之所以不使用propArr.Length,是因为有些Models的属性在数据表中不存在对应的列 { propArr[j].SetValue(t, rows[i][j]); } list.Add(t); t = default(T); } return list; } /// <summary> /// 功能: /// DataRow的扩展方法; /// 能够将DataRow对象封装到泛型对象中 /// </summary> /// <typeparam name="T">需要转换成为的class类型</typeparam> /// <param name="row">被转换的行</param> /// <returns>封装了行数据的class对象</returns> public static T RowToClass<T>(this DataRow row) { //Type type = Assembly.Load(classFullName).GetType(); Type type = typeof(T); T t = (T)Activator.CreateInstance(type); PropertyInfo[] propArr = type.GetProperties(); int len = row.ItemArray.Length; for (int i = 0; i < len; i++) { propArr[i].SetValue(t, row[i]); } return t; } /// <summary> /// 功能: /// DataRowCollection的扩展方法; /// 能够将DataRowCollection对象封装到泛型List集合中 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="rows"></param> /// <returns></returns> public static List<T> RowToClass<T>(this DataRow row, DataRow[] rowArr) { Type type = typeof(T); PropertyInfo[] propArr = type.GetProperties(); int len = rowArr[0].ItemArray.Length;//获取数据表第一行的列数,即属性个数 List<T> list = new List<T>(); for (int i = 0; i < rowArr.Length; i++) { T t = (T)Activator.CreateInstance(type); for (int j = 0; j < len; j++) { propArr[j].SetValue(t, rowArr[i][j]); } list.Add(t); t = default(T); } return list; } }}上面用到了泛型,反射,扩展方法。
之前在使用这行代码时出了点小问题:
propArr[i].SetValue(t, row[i]);
报了一个类型转换异常,断点调试之后发现是因为 Models 中的属性的排列和数据表的列的顺序不一样导致的,参照数据表中字段的顺序修改过来就好,还有一点就是在循环对属性进行赋值时,我选用的是数据表中列的个数,而不是属性的个数,(也就是代码中这里之所以不使用propArr.Length,是因为有些Models的属性在数据表中不存在对应的列
)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#根据反射和特性实现ORM映射的方法。分享给大家供大家参考。具体如下:(一)关于反射什么是反射?反射就是在运行时,动态获取对象信息的方法。比如:
本文实例讲述了C#使用晚绑定来实现压缩Access数据库的方法,通常来说VB对Com后期绑定支持得很好,在C#中可以使用反射来实现。具体方法如下:函数实现代码如
本文所述实例为C#运用FileInfo类实现拷贝文件的方法,程序中C#首先创建一个StreamWriter对象writer,它向FileInfo的实例srcFi
反射调用返回复杂对象的.NET方法定义数据接口上一篇在C++中反射调用.NET(一)中,我们简单的介绍了如何使用C++/CLI并且初步使用了反射调用.NET程序
本文实例汇总了C#中String类常用方法。分享给大家供大家参考。具体分析如下:C#中的String类很有用,下面是一些它的常用方法的总结,如果灵活运用这些的话