怎样简单灵活地将DataTable中的数据赋值给model
最近在做的一个项目中,有13个方法都需要用到同一种处理方式:通过SQL语句从数据库获取一条指定的数据,并将该数据中的每个值都赋值给一个model,再将这个model中的数据通过微信发送出去。每个方法都会从不同的表中获取数据,需要处理的数据完全不同,因此也对应了13个不同的model。这些model中的每个属性名称是已经给定的,需要将它们post出去,使用微信给定的模板发送消息,因此每个属性的名称必须与微信提供的模板中一致。
下面举个简单的例子来说明当前的情况:
SQL Server中用来存放数据的其中一个表结构如下(实际的字段有十几个):
create table memberinfo
(
member_id int,
member_name varchar(20),
member_birthday varchar(50)
)
go
需要传给微信消息模板的其中一个参数model如下:
/// <summary>
/// 微信消息中的参数
/// </summary>
public class wechatouputpara
{
private String _name = "";
/// <summary>
/// 会员姓名
/// </summary>
public String name
{
get { return _name ; }
set { _name = value; }
} private String _birthday= "";
/// <summary>
/// 会员生日
/// </summary>
public String birthday
{
get { return _birthday; }
set { _birthday= value; }
}
}
需要达到的最终效果:将数据库memberinfo表中的一条会员信息获取出来,并将姓名member_name赋值给wechatouputpara类的name属性,将生日member_birthday赋值给birthday属性。
注意:这里只是举了一个简单的例子,实际并不是把某个表中的字段直接转换成某个类的,而是要通过存储过程,将多个表联合查询出的结果进行转换的,并且查询的语句可能比较复杂。这个例子只是为了说明,一个已经存到DataTable里的数据,如何赋值给指定类中的同名属性,仅此而已。
既然有很多方法都需要用同一种方式处理,那么自然而然要想到有没有一种能够公用的方法,一劳永逸。毕竟每个表的结构是不同的,传回的数据可能多达十几二十几个字段,如果每个方法中,都要将表中每个字段的值依次赋值给model中的对应属性,那么工作量和代码量都会非常大。
我的解决办法如下:
(1)通过SQL语句从表中获取数据时,将每个字段转换为与model中的对应属性相同的名称。
(2)写一个方法,能够将DataTable表中的每一个字段赋值给model中与其名称相同的属性。
(3)使用泛型,将这个方法作为一个公用方法,每个数据表向对应model中赋值时,都可以调用这个方法。
接下来,仍然使用上面列出的简单例子,来说明最终的解决方案。
(1)使用SQL语句获取数据:
select member_name as [name],member_birthday as birthday from memberinfo where member_id = 1
在代码中,获取到的数据被存到DataTable dtInfo中。
(2)写一个公用方法,实现:将DataTable表中的每一个字段赋值给model中与其名称相同的属性。
/// <summary>
/// 将DataTable中的每一列赋值给model中的同名属性
/// DataTable中只有一行数据
/// </summary>
/// <typeparam name="T">泛型:model的类型</typeparam>
/// <param name="objmodel">model的实例</param>
/// <param name="dtInfo">DataTable表</param>
public void TableToModel<T>(T objmodel, DataTable dtInfo)
{
//获取model的类型
Type modelType = typeof(T); //获取model中的属性
PropertyInfo[] modelpropertys = modelType.GetProperties(); //遍历DataTable的每一列
for (Int32 i = ; i < dtInfo.Columns.Count; i++)
{
//遍历model的每一个属性
foreach (PropertyInfo pi in modelpropertys)
{
String name = pi.Name; //获取属性名称
//若model属性名称与表中的列名相同
if (name == dtInfo.Columns[i].ColumnName)
{
//获取表中该列对应的数据
object value = dtInfo.Rows[][i].ToString();
//将表中该列下的数据赋值给model中的同名属性
modelType.GetProperty(name).SetValue(objmodel, value, null);
}
}
}
}
(3)在代码中调用公用方法,将DataTable dtInfo中的数据赋值给wechatouputpara类。
//输出参数
wechatouputpara objwechatouputpara = new wechatouputpara(); //将会员信息赋值给输出参数
TableToModel<wechatouputpara>(objwechatouputpara, dtInfo);
问题解决了,13个类似的方法都可以直接一句话调用这个公用方法,就可以完成赋值操作,是不是简单多了呢?并且,如果数据表的结构发生变化,或者微信消息需要添加、删除参数,只需要修改SQL语句和对应的model即可,不需要去修改对应的赋值语句,非常灵活。
怎样简单灵活地将DataTable中的数据赋值给model的更多相关文章
- DataTable中的数据赋值给model z
create table memberinfo ( member_id int, member_name varchar(20), member_birthday varchar(50) ) go / ...
- 从DataTable中查询数据
/// <summary> /// 从DataTable中查询数据 /// </summary> /// <param name="tb">待处 ...
- SqlBulkCopy将DataTable中的数据批量插入数据库中
#region 使用SqlBulkCopy将DataTable中的数据批量插入数据库中 /// <summary> /// 注意:DataTable中的列需要与数据库表中的列完全一致.// ...
- 【转载】C#中遍历DataTable中的数据行
在C#中的Datatable数据变量的操作过程中,有时候我们需要遍历DataTable变量获取每一行的数据值,例如将DataTable变量转换为List集合的时候,我们就会遍历DataTable变量, ...
- list转datatable,SqlBulkCopy将DataTable中的数据批量插入数据库
/// <summary> /// 将泛类型集合List类转换成DataTable /// </summary> /// <param name="list&q ...
- DataTable数据赋值给Model通用方法
注:该文属本人原创,今后项目中发现该方法存在BUG会实时更新,转载记得附上原文出处,方便大家获得最新代码. 相信大家在做项目中,经常会根据不同的表new各种不同的Model,当需要对Model进行实例 ...
- c#.net循环将DataGridView中的数据赋值到Excel中,并设置样式
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel ...
- 弹框勾选datatable中的数据,点击保存后添加到另一个表中,同一个页面
需求描述:做编辑的时候,点击添加按钮,弹出数据表table2,勾选弹出框中的数据,点击保存后能够添加到table1中,并且已经被添加到table1中的数据,在弹出框中显示已选,checkbox隐藏:t ...
- C#如何对DataTable中的数据进行条件搜索
经常遇到将数据库中的数据读取到DataTable中的时候再次对DataTable进行条件筛选,下面的筛选的一个例子: DataRow[] dr = dt.Select("token = '& ...
随机推荐
- ASP.NET Core 中文文档 第四章 MVC(2.3)格式化响应数据
原文:Formatting Response Data 作者:Steve Smith 翻译:刘怡(AlexLEWIS) 校对:许登洋(Seay) ASP.NET Core MVC 内建支持对相应数据( ...
- 【中文分词】隐马尔可夫模型HMM
Nianwen Xue在<Chinese Word Segmentation as Character Tagging>中将中文分词视作为序列标注问题(sequence labeling ...
- AJAX(一)
AJAX(一) Ajax是Asynchronous Javascript和XML的简写,这一技术能够向服务器请求额外的数据而无需卸载页面,会带来更好的用户体验. [前面的基础知识][关于同步和异步的了 ...
- Autofac 组件、服务、自动装配 《第二篇》
一.组件 创建出来的对象需要从组件中来获取,组件的创建有如下4种(延续第一篇的Demo,仅仅变动所贴出的代码)方式: 1.类型创建RegisterType AutoFac能够通过反射检查一个类型,选择 ...
- JavaScript原型OOP——你上车了吗?
.title-bar { width: 80%; height: 35px; padding-left: 35px; color: white; line-height: 35px; font-siz ...
- Android 5.0源码编译问题
如果是自己通过repo和git直接从google官网上download的源码,请忽略这个问题,但是由于google在国内被限制登录,通过这一种方法不是每个人都能download下来源码,通常的做法就是 ...
- Android Service
一.在MainAcitivity界面启动Service : public class MyService extends Service intent = new Intent(MainActivi ...
- Struts+Spring+Hibernate项目的启动线程
在Java Web项目中,经常要在项目开始运行时启动一个线程,每隔一定的时间就运行一定的代码,比如扫描数据库的变化等等.要实现这个功能,可以现在web.xml文件中定义一个Listener,然后在这个 ...
- Linux安装jdk
查看Java的版本命令:java -version 查看java版本的方法是:运行--->cmd,输入java –version.注意: java命令后是有个空格的,-version表示参数而已 ...
- laravel安装
简单概括:Laravel是一套简洁.优雅的PHP Web开发框架(PHP Web Framework).它可以让你从面条一样杂乱的代码中解脱出来:它可以帮你构建一个完美的网络APP,而且每行代码都可以 ...