DataSet与泛型集合间的转换

简介:

基本思路 

利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值。注意:从DataSet到IList<T>的转换,自定义类型的公开属性必须与DataTable中的字段名称一致,才能到达想要的结果。建议DataTable的定义从数据库来,自定义类型用O/R Mapping的方式获得。 

代码说明 



/// <summary> 
/// 泛型集合与DataSet互相转换 
/// </summary> 
public class IListDataSet 


/// <summary> 
/// 集合装换DataSet 
/// </summary> 
/// <param name="list">集合</param> 
/// <returns></returns> 
/// 2008-08-01 22:08 HPDV2806 
public static DataSet ToDataSet( IList p_List ) 

DataSet result = new DataSet(); 
DataTable _DataTable = new DataTable(); 
if ( p_List.Count > 0 ) 

PropertyInfo[] propertys = p_List[0].GetType().GetProperties(); 
foreach ( PropertyInfo pi in propertys ) 

_DataTable.Columns.Add( pi.Name, pi.PropertyType ); 


for ( int i = 0; i < p_List.Count; i++ ) 

ArrayList tempList = new ArrayList(); 
foreach ( PropertyInfo pi in propertys ) 

object obj = pi.GetValue( p_List[i], null ); 
tempList.Add( obj ); 

object[] array = tempList.ToArray(); 
_DataTable.LoadDataRow( array, true ); 


result.Tables.Add( _DataTable ); 
return result; 


/// <summary> 
/// 泛型集合转换DataSet 
/// </summary> 
/// <typeparam name="T"></typeparam> 
/// <param name="list">泛型集合</param> 
/// <returns></returns> 
/// 2008-08-01 22:43 HPDV2806 
public static DataSet ToDataSet<T>( IList<T> list ) 

return ToDataSet<T>( list, null ); 



/// <summary> 
/// 泛型集合转换DataSet 
/// </summary> 
/// <typeparam name="T"></typeparam> 
/// <param name="p_List">泛型集合</param> 
/// <param name="p_PropertyName">待转换属性名数组</param> 
/// <returns></returns> 
/// 2008-08-01 22:44 HPDV2806 
public static DataSet ToDataSet<T>( IList<T> p_List, params string[] p_PropertyName ) 

List<string> propertyNameList = new List<string>(); 
if ( p_PropertyName != null ) 
propertyNameList.AddRange( p_PropertyName ); 

DataSet result = new DataSet(); 
DataTable _DataTable = new DataTable(); 
if ( p_List.Count > 0 ) 

PropertyInfo[] propertys = p_List[0].GetType().GetProperties(); 
foreach ( PropertyInfo pi in propertys ) 

if ( propertyNameList.Count == 0 ) 

// 没有指定属性的情况下全部属性都要转换 
_DataTable.Columns.Add( pi.Name, pi.PropertyType ); 

else 

if ( propertyNameList.Contains( pi.Name ) ) 
_DataTable.Columns.Add( pi.Name, pi.PropertyType ); 



for ( int i = 0; i < p_List.Count; i++ ) 

ArrayList tempList = new ArrayList(); 
foreach ( PropertyInfo pi in propertys ) 

if ( propertyNameList.Count == 0 ) 

object obj = pi.GetValue( p_List[i], null ); 
tempList.Add( obj ); 

else 

if ( propertyNameList.Contains( pi.Name ) ) 

object obj = pi.GetValue( p_List[i], null ); 
tempList.Add( obj ); 



object[] array = tempList.ToArray(); 
_DataTable.LoadDataRow( array, true ); 


result.Tables.Add( _DataTable ); 
return result; 


/// <summary> 
/// DataSet装换为泛型集合 
/// </summary> 
/// <typeparam name="T"></typeparam> 
/// <param name="p_DataSet">DataSet</param> 
/// <param name="p_TableIndex">待转换数据表索引</param> 
/// <returns></returns> 
/// 2008-08-01 22:46 HPDV2806 
public static IList<T> DataSetToIList<T>( DataSet p_DataSet, int p_TableIndex ) 

if ( p_DataSet == null || p_DataSet.Tables.Count < 0 ) 
return null; 
if ( p_TableIndex > p_DataSet.Tables.Count - 1 ) 
return null; 
if ( p_TableIndex < 0 ) 
p_TableIndex = 0; 

DataTable p_Data = p_DataSet.Tables[p_TableIndex]; 
// 返回值初始化 
IList<T> result = new List<T>(); 
for ( int j = 0; j < p_Data.Rows.Count; j++ ) 

T _t = (T)Activator.CreateInstance( typeof( T ) ); 
PropertyInfo[] propertys = _t.GetType().GetProperties(); 
foreach ( PropertyInfo pi in propertys ) 

for ( int i = 0; i < p_Data.Columns.Count; i++ ) 

// 属性与字段名称一致的进行赋值 
if ( pi.Name.Equals( p_Data.Columns[i].ColumnName ) ) 

// 数据库NULL值单独处理 
if ( p_Data.Rows[j][i] != DBNull.Value ) 
pi.SetValue( _t, p_Data.Rows[j][i], null ); 
else 
pi.SetValue( _t, null, null ); 
break; 



result.Add( _t ); 

return result; 


/// <summary> 
/// DataSet装换为泛型集合 
/// </summary> 
/// <typeparam name="T"></typeparam> 
/// <param name="p_DataSet">DataSet</param> 
/// <param name="p_TableName">待转换数据表名称</param> 
/// <returns></returns> 
/// 2008-08-01 22:47 HPDV2806 
public static IList<T> DataSetToIList<T>( DataSet p_DataSet, string p_TableName ) 

int _TableIndex = 0; 
if ( p_DataSet == null || p_DataSet.Tables.Count < 0 ) 
return null; 
if ( string.IsNullOrEmpty( p_TableName ) ) 
return null; 
for ( int i = 0; i < p_DataSet.Tables.Count; i++ ) 

// 获取Table名称在Tables集合中的索引值 
if ( p_DataSet.Tables[i].TableName.Equals( p_TableName ) ) 

_TableIndex = i; 
break; 


return DataSetToIList<T>( p_DataSet, _TableIndex ); 





使用范围 

1. 可以用在业务层中数据获取,获取DataSet的同时也可以转为IList集合为调用者所使用。 

2. 在WebServices中传输自定义类型使用,即传递参数都用DataSet类型(WebServices直接支持的数据类型),在使用前将其转换为IList来使用。

           本文转自灵动生活博客园博客,原文链接:http://www.cnblogs.com/ywqu/archive/2009/01/04/1368026.html,如需转载请自行联系原作者

相关文章
|
缓存 监控 Java
手把手教你在服务器如何免费搭建一套GPS定位系统平台
GPS定位系统一般是指部署在服务器端可以监控各类GPS北斗卫星定位硬件设备的系统软件,比如实时的位置和行驶轨迹等等。
5733 0
手把手教你在服务器如何免费搭建一套GPS定位系统平台
|
存储 数据安全/隐私保护
STM32实战项目—密码锁
本文完整详细地介绍了一个密码锁项目的要求,设计思路,程序实现,问题总结和成果展示内容。
666 2
STM32实战项目—密码锁
|
JavaScript 数据挖掘
jupyter平台最强插件没有之一
jupyter平台最强插件没有之一
178 3
基于MPPT最大功率跟踪和SVPWM的光伏三相并网逆变器simulink建模与仿真
本课题基于Simulink建模与仿真,研究了光伏三相并网逆变器。系统包括PV模块、MPPT模块、SVPWM模块和电网模块。通过MPPT确保光伏阵列始终工作在最大功率点,SVPWM生成高质量的三相电压输出,提高能量转换效率。仿真结果展示了不同光照条件下系统的输出电压、功率及并网性能。核心程序基于MATLAB2022a实现。
|
存储 编译器 数据安全/隐私保护
【C++篇】C++类与对象深度解析(四):初始化列表、类型转换与static成员详解2
【C++篇】C++类与对象深度解析(四):初始化列表、类型转换与static成员详解
181 3
|
Web App开发 存储 前端开发
《Chrome谷歌插件Top10》开发最好用的谷歌插件
本文介绍了多个实用的浏览器插件及其安装方法。包括CSDN浏览器助手,提供高效开发工具;FeHelper,前端必备工具,支持格式化、压缩等功能;uBlock Origin,有效屏蔽广告和弹窗;PageLiner,网页标尺工具,便于前端设计;Fatkun,批量下载图片;Smallpdf,文件转换工具;Octotree,GitHub代码树插件;Awesome Screenshot,截图与录屏工具;ColorZilla,颜色拾取器;Dark Reader,暗黑模式阅读插件。安装方式有通过Chrome商店搜索或下载crx插件本地安装。
426 11
|
前端开发 JavaScript
前端 JS 经典:下载的流式传输
前端 JS 经典:下载的流式传输
231 1
|
Dubbo 网络协议 Java
性能基础之常见RPC框架浅析
【4月更文挑战第23天】性能基础之常见RPC框架浅析
675 1
性能基础之常见RPC框架浅析
|
缓存 搜索推荐 网络安全
Google Hacking
Google Hacking,也称为Google Dorking,是一种利用Google搜索引擎和其高级搜索技术来查找安全漏洞、敏感信息或用于渗透测试的特定数据的技术。
303 11
|
监控 机器人 区块链
深度分析——狩猎者defi夹子机器人系统开发技术原理
过去一年的时间里,DeFi可谓是迅速崛起,发展态势极其迅猛。虽然DeFi尚处于发展早期阶段,但活跃度和参与度都呈指数地在增长。在DeFi中,交易被打包的顺序极大地影响了DeFi的经济利益。例如,在 UniSwap 中,同样两个针对某交易对的买单,先被执行的交易将获得更多代币。若你在一笔买单前买入同样的代币,然后又赶紧卖出,则将毫无风险的获利。
深度分析——狩猎者defi夹子机器人系统开发技术原理