利用.NET反射机制实现IList到DataTable转换

本文 意义并不仅仅是为了介绍说明如何将IList转换为DataTable 而是给出 个利用反射来实现对各种数据结构(集合类)相互转换 通用思路方法 编写思路.
相信很多使用过Nhibernate 朋友都知道 通过NH访问数据库 数据都是以ILIST形式返回 这就为我们在.NET中使用传统 数据绑定造成了不便 由于NH返回 ILIST所装载 对象往往都是区别 我们会为每个返回 LIST单独编写转换思路方法 而利用反射机制却可以做成通用 转换思路方法.
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Collections;
using System.Reflection;

namespace  KycBaseModule
{
public KycFunction
{
public KycFunction(){ }
/** <summary>
/// 实现对IList到DataSet 转换
/// </summary>
/// <param name="ResList">待转换 IList</param>
/// <returns>转换后 DataSet</returns>
public static DataSet ListToDataSet(IList ResList)
{
DataSet RDS=new DataSet ;
DataTable TempDT = new DataTable ;

//此处遍历IList 结构并建立同样 DataTable
System.Reflection.PropertyInfo p = ResList[0].GetType().GetProperties();
foreach (System.Reflection.PropertyInfo pi in p)
{
TempDT.Columns.Add(pi.Name,System.Type.GetType(pi.PropertyType.ToString()));
}

for (int i = 0; i < ResList.Count; i++)
{
IList TempList = new ArrayList ;
//将IList中 条记录写入ArrayList
foreach (System.Reflection.PropertyInfo pi in p)
{
object oo = pi.GetValue(ResList[i], null);
TempList.Add(oo);
}

object  itm=new object[p.Length];
//遍历ArrayList向object里放数据
for (int j = 0; j < TempList.Count; j++)
{
itm.SetValue(TempList[j], j);
}
//将object 内容放入DataTable
TempDT.LoadDataRow(itm, true);
}
//将DateTable放入DataSet
RDS.Tables.Add(TempDT);
//返回DataSet
return RDS;
}
}
}

由上面 代码可以看出 实现 过程非常简单 首先利用反射 将传入思路方法 IList中 对象所包含 属性进行获取 然后根据获取 属性建立DataTable Columns 然后利用循环遍历整个IList 将每个结点对象所包含 内容依次复制到DataTable 由于该代码取自真实 项目模块 所以保留了原有 命名空间和将DataTable放入DataSet 几行.

转载于:https://www.cnblogs.com/arongbest/archive/2009/06/12/1502200.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值