博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
.Net中List<T> 泛型转成DataTable、DataSet
阅读量:5927 次
发布时间:2019-06-19

本文共 3346 字,大约阅读时间需要 11 分钟。

在开发过程过程中有时候需要将List<T>泛型转换成DataTable、DataSet,可以利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值。

1、List<T>泛型转换成DataTable 代码:

///         /// List
转换成DataTable ///
///
/// /// 集合数据 ///
返回DataTable
public static System.Data.DataTable ToDataTable
(this System.Collections.Generic.IList
list, System.Collections.Generic.IList
dataList) where T : class ,new() { if (dataList == null || !dataList.Any()) { return null; } Type type = typeof(T); System.Data.DataTable dt = new System.Data.DataTable(type.Name); System.Reflection.PropertyInfo[] propertyInfoArray = type.GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance); foreach (T t in dataList.Where(t => t != null)) { System.Data.DataRow row = dt.NewRow(); for (int i = 0, j = propertyInfoArray.Length; i < j; i++) { System.Reflection.PropertyInfo propertyInfo = propertyInfoArray[i]; string name = propertyInfo.Name; if (dt.Columns[name] == null) { System.Data.DataColumn column = new System.Data.DataColumn(name, propertyInfo.PropertyType); dt.Columns.Add(column); } row[name] = propertyInfo.GetValue(t, null); } dt.Rows.Add(row); } return dt; }

 

2、List<T>泛型转换成DataSet 代码:

///         /// List
转换成DataSet ///
///
/// /// 集合数据 ///
返回DataSet
public static System.Data.DataSet ToDataSet
(this System.Collections.Generic.IList
list, System.Collections.Generic.IList
dataList) where T : class ,new() { if (dataList == null || !dataList.Any()) { return null; } Type type = typeof(T); System.Data.DataSet ds = new System.Data.DataSet(); System.Data.DataTable dt = new System.Data.DataTable(type.Name); System.Reflection.PropertyInfo[] propertyInfoArray = type.GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance); foreach (T t in dataList.Where(t => t != null)) { System.Data.DataRow row = dt.NewRow(); for (int i = 0, j = propertyInfoArray.Length; i < j; i++) { System.Reflection.PropertyInfo propertyInfo = propertyInfoArray[i]; string name = propertyInfo.Name; if (dt.Columns[name] == null) { System.Data.DataColumn column = new System.Data.DataColumn(name, propertyInfo.PropertyType); dt.Columns.Add(column); } row[name] = propertyInfo.GetValue(t, null); } dt.Rows.Add(row); } ds.Tables.Add(dt); return ds; }

 

转载于:https://www.cnblogs.com/linJie1930906722/p/6045090.html

你可能感兴趣的文章
Visual Studio 清单(manifest)导致的问题
查看>>
Sphinx全文检索引擎测试
查看>>
16-djongo中间件学习
查看>>
【tomcat】servlet原理及其生命周期
查看>>
2018-04-12
查看>>
onmouseover-onmouseout
查看>>
用diss 实现 push动画
查看>>
(一)easyUI之树形网络
查看>>
前端工程化
查看>>
Makefile 使用总结
查看>>
Class与Style绑定
查看>>
FZU 2095 水面高度
查看>>
sql 中 limit 与 limit,offset连用的区别
查看>>
如何改变X:\Users\XXX的用户名称
查看>>
玄学搜索\随稽化
查看>>
(转)完美画质 3D游戏反锯齿技术浅析 .
查看>>
SharedPreferences操作数据
查看>>
如何添加自定义icon
查看>>
PHP性能追踪及分析工具xhprof的安装与使用
查看>>
Spring下载地址
查看>>