用反射写自己的DataTable转为对应的Mod
之前写过类似的方法,今天做项目的时候又遇到了,以前的代码没有保存,导致又得重新写
场景:当我们定义自己的很多模型(Mods)的时候,而数据库读取出来的却是DataSet,DataTable类型的时候,我们想在界面上绑定控件的时候需要
将DataTable转为Mods
下面是我的代码,switch里面的类型判断可能不是很详细,具体的需要手动修改,加上异常,我这边测试只做了抛出....
/// <summary>
/// 模型帮助类
/// 主要功能:实现DataTable与Modle之间的互相转换
/// Created by zwm 2015-11-19
/// </summary>
public class ModHelper
{
/// <summary>
/// 将DataTable类型转为List<T>
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dt"></param>
/// <returns></returns>
public static List<T> DataTabelToList<T>(DataTable dt)
{
List<T> list=new List<T>();
try
{
if (dt == null || dt.Rows.Count <= 0)
return null;
Type type = typeof(T);
System.Reflection.PropertyInfo[] properties = type.GetProperties();
for (int i = 0; i < dt.Rows.Count;i++ )
{
object obj = type.Assembly.CreateInstance(type.FullName);
foreach (System.Reflection.PropertyInfo property in properties)
{
if (dt.Columns.Contains(property.Name))//存在该列
{
if (dt.Rows[i][property.Name] == null || string.IsNullOrWhiteSpace(dt.Rows[i][property.Name].ToString()))
{
continue;
}
switch (property.PropertyType.Name)
{
case "String":
property.SetValue(obj, dt.Rows[i][property.Name].ToString());
break;
case "Int16":
property.SetValue(obj, Convert.ToInt16(dt.Rows[i][property.Name]));
break;
case "Int32":
property.SetValue(obj, Convert.ToInt32(dt.Rows[i][property.Name]));
break;
case "Int64":
property.SetValue(obj, Convert.ToInt32(dt.Rows[i][property.Name]));
break;
case "bool":
property.SetValue(obj, Convert.ToBoolean(dt.Rows[i][property.Name]));
break;
case "Decimal":
property.SetValue(obj, Convert.ToDecimal(dt.Rows[i][property.Name]));
break;
case "DateTime" :
property.SetValue(obj, Convert.ToDateTime(dt.Rows[i][property.Name]));
break;
default: //有些类型需要转换
Yinoer.YnCommon.Debug.WriteException(new Exception("模型转换的时候-有些类型可能需要转换!"));
break;
}
}
}
list.Add((T)obj);
}
return list;
}
catch (Exception ex)
{
throw ex;//测试的时候用来抛出异常
}
}
用反射写自己的DataTable转为对应的Mod的更多相关文章
- .net 利用Emit将object转为DbParameter,DataTable转为List<>
先放测试结果图,测试的方法是拷贝了老赵的一个简单的性能计数器:CodeTimer.发现速度还是比利用反射来获取快了2倍左右的,将object转为DbParameter的反射方法我没写. ...
- 自己用反射写的一个request.getParameter工具类
适用范围:当我们在jsp页面需要接收很多值的时候,如果用request.getParameter(属性名)一个一个写的话那就太麻烦了,于是我想是 否能用反射写个工具类来简化这样的代码,经过1个小时的代 ...
- 应用反射写的tostring方法
应用反射写的tostring方法 应用反射写的tostring方法,方便以后查询 代码 package com.chzhao.reflecttest; import java.lang.reflect ...
- DataTable转List,DataTable转为Model对象帮助类
DataTable转List,DataTable转为Model对象帮助类 public class ModelConvertHelper<T> where T : new() { publ ...
- C#实现DataTable转为Excel文件
实现DataTable转为Excel文件,和上次分享的Excel文件转为DataTable互为反操作.DataTable转化为Excel文件是通过传入一个DataTable类型的参数,然后将传入的Da ...
- 反射类属性生成DataTable
public class People //类名 { private static string name; //字段 private string sex;//字段 public string Se ...
- 反射小应用之DataTable和List<T>互操作
在程序中,往往会遇到一些小情况,就是数据库取出来的时候为了方便直接将数据通过存储在DataSet或DataTable中,这样做的一个后果是在日后的的对数据进行”细“操作时,就发现它可能没有List&l ...
- 用反射,将DataRow行转为Object对象
/// <summary> /// 反射辅助类 /// </summary> public class ReflectionHelper { /// <summary&g ...
- Silverlight中如何自己写方法将DataTable转换为PagedCollectionView数据(动态创建类)
将DataTable转换为PagedCollectionView数据,我们可以借用DataTable的GetBindableData()方法,如下: DataTable dt=new DataTabl ...
随机推荐
- HortonWorks
http://zh.hortonworks.com/products/hortonworks-sandbox/
- Wide character in print at hcp.pl line 21.
jrhmpt01:/root# cat -n hcp.pl 1 use LWP::UserAgent; 2 use Encode; 3 $ua = LWP::UserAgent->new; 4 ...
- 预处理指令中#Pragma
在所有的预处理指令中,#Pragma 指令可能是最复杂的了,它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作.#pragma指令对每个编译器给出了一个方法,在保持与C和C++语言完全兼容的 ...
- Summer Holiday(强联通入度最小点)
Summer Holiday Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- web浏览器中的javascript 1
Html 文档嵌入客户端有4种方式. 1. 内联.放置在<script>和</script>标签对之间. 2.放置在<script>标签的src属性指定的外部文件中 ...
- SQL Server索引进阶:第八级,唯一索引
原文地址: Stairway to SQL Server Indexes: Level 8,Unique Indexes 本文是SQL Server索引进阶系列(Stairway to SQL Ser ...
- 【踩坑】近来在Firefox上遇到的一些坑
因为工作一年多以来,做的工作基本都是和webkit系列打交道. 先是做m站,后来做了两个app内嵌的hybrid项目,从来只考虑webkit前缀和相关的伪类. 最近四个多月开始做内部的管理系统,写写样 ...
- bmob云 实现注册和登录的功能
向大家介绍一款我感觉非常溜的一款后端云服务bmob云 借助bmob云我们可以实现注册和登录页面的功能,下面就让我给大家演示一下借助bmob云服务实现这两个功能吧. 1. 用户是一个应用程序的核心.对 ...
- CodeForces 452C Magic Trick (排列组合)
#include <iostream> #include <cstdio> #include<cmath> #include<algorithm> us ...
- 如何最简单的优化MySql
1.创建索引,一定要根据实际情况来创建,如果是连接表查询,如一个主帐号连接多个子帐号,可以考虑两个或三个以上的多索引: 2.合理利用时间排序,由于大多数表格用时间来排序,数据量相当大的时候,在时间列上 ...