用反射写自己的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 ...
随机推荐
- page cache和buffer cache
因为要优化I/O性能,所以要理解一下这两个概念,这两个cache着实让我迷糊了好久,通过查资料大概明白了两者的区别,试着说下. page cache:文件系统层级的缓存,从磁盘里读取的内容是存储到这里 ...
- 加密解密技术—Web.config加密和解密
阅读目录 一:我们为什么要对web.config配置文件中的配置节加密? 二:怎么样加密和解密? 三:实例 四:运行效果 一:我们为什么要对web.config配置文件中的配置节加密? 因为在我们的项 ...
- mobile web 手机开发
1. -webkit-tap-highlight-color -webkit-tap-highlight-color:rgba(255,255,255,0); 用来把android上点击网页时出现 ...
- 转: linux文件链接(软链接和硬链接)
链接:一种在共享文件和访问它的用户的若干目录项之间建立联系的一种方法. Linux中包括两种链接:硬链接(Hard Link)和软链接(Soft Link),软链接又称为符号链接(Symbolic l ...
- Orz 终于有了自己的博客地址
新博客地址:http://www.wnjxyk.cn/
- JAVA异常设计原则
异常是面向对象语言非常重要的一个特性,良好的异常设计对程序的可扩展性.可维护性.健壮性都起到至关重要. JAVA根据用处的不同,定义了两类异常 * Checked Exception: Exc ...
- C#中两个整数相除得到带小数点的结果
有时候需要将两个整数相除,获得带小数点的float类型数.例如一个整数12345,需要变成123.45.常见与串口与硬件通讯,DSP处理浮点型比较麻烦,DSP传递来的温度等数据都以整型的方式传递,串口 ...
- 深入理解 IE haslayout
转载自Bubblings Blog 原文地址:http://riny.net/2013/haslayout/ 1.什么是haslayout layout是windows IE的一个私有概念,它决定了元 ...
- MVC过滤器基本使用
Action过滤器 /// <summary> /// 执行代码前执行 /// </summary> /// <param name="filterCo ...
- Hadoop学习笔记(1)概述
写在学习笔记之前的话: 寒假已经开始好几天了,似乎按现在的时间算,明天就要过年了.在家的这几天,该忙的也都差不多了,其实也都是瞎忙.接下来的几点,哪里也不去了,静静的呆在家里学点东西.所以学习一下Ha ...