前段时间做了一个练手的小项目,名叫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的属性在数据表中不存在对应的列
)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# C#
# 反射
# 扩展方法
# 详解C#扩展方法原理及其使用
# C#中的扩展方法详解
# 基于C# MBG 扩展方法类库的使用详解
# C# Winform使用扩展方法实现自定义富文本框(RichTextBox)字体颜色
# C#特性 扩展方法
# C# 扩展方法详解
# 是因为
# 的是
# 装了
# 中不
# 类中
# 成了
# 出了
# 就好
# 把它
# 写了
# 顾名思义
# 来做
# 转变为
# 前段时间
# 报了
# 大家多多
# 这行
# 有一个
# 象中
# 而不是
相关文章:
如何在IIS中新建站点并配置端口与IP地址?
网站制作免费,什么网站能看正片电影?
如何解决ASP生成WAP建站中文乱码问题?
高防服务器租用指南:配置选择与快速部署攻略
建站之星客服服务时间及联系方式如何?
如何快速生成ASP一键建站模板并优化安全性?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
网站制作企业,网站的banner和导航栏是指什么?
清除minerd进程的简单方法
如何选择高效可靠的多用户建站源码资源?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何在阿里云虚拟服务器快速搭建网站?
建站之星CMS五站合一模板配置与SEO优化指南
如何在云主机快速搭建网站站点?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
如何高效完成自助建站业务培训?
建站主机如何安装配置?新手必看操作指南
深圳网站制作案例,网页的相关名词有哪些?
独立制作一个网站多少钱,建立网站需要花多少钱?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
广州商城建站系统开发成本与周期如何控制?
Python路径拼接规范_跨平台处理说明【指导】
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何用5美元大硬盘VPS安全高效搭建个人网站?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
如何在云服务器上快速搭建个人网站?
高防服务器如何保障网站安全无虞?
中山网站制作网页,中山新生登记系统登记流程?
如何自定义建站之星网站的导航菜单样式?
如何选择最佳自助建站系统?快速指南解析优劣
建站主机选择指南:服务器配置与SEO优化实战技巧
济南网站建设制作公司,室内设计网站一般都有哪些功能?
如何确保西部建站助手FTP传输的安全性?
建站之星如何实现PC+手机+微信网站五合一建站?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
如何在景安云服务器上绑定域名并配置虚拟主机?
大连网站制作公司哪家好一点,大连买房网站哪个好?
油猴 教程,油猴搜脚本为什么会网页无法显示?
linux top下的 minerd 木马清除方法
专业商城网站制作公司有哪些,pi商城官网是哪个?
如何在企业微信快速生成手机电脑官网?
如何生成腾讯云建站专用兑换码?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
TestNG的testng.xml配置文件怎么写
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
建站之星如何助力企业快速打造五合一网站?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
代购小票制作网站有哪些,购物小票的简要说明?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。