DataSet和List<T> 泛型之间互相转换 (转载, 作者写的很好)

//DataSet与泛型集合间的互相转换

//利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值。

//注意:从DataSet到IList<T>的转换,自定义类型的公开属性必须与DataTable中的字段名称

//一致,才能到达想要的结果。建议DataTable的定义从数据库来,自定义类型用O/R Mapping的方式获得。

//代码说明

/// <summary>

/// 泛型集合与DataSet互相转换

/// </summary>

using System.Data;

using System.Reflection;

using System.Collections;

using System.Collections.Generic;

using System;

namespace qdl
{

public class IListDataSet
    {

/// <summary>

/// 集合装换DataSet

/// </summary>

/// <param name="list">集合</param>

/// <returns></returns>

/// 2008-8-1 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-8-1 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-8-1 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-8-1 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-8-1 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来使用。

* ******************************/

}

DataSet和List 泛型之间互相转换 (转载, 作者写的很好)相关推荐

  1. DataSet和ListT 泛型之间互相转换 (转载, 作者写的很好)

    /DataSet与泛型集合间的互相转换 //利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值. //注意:从DataSet到IList<T>的转换,自定义类型的公开属性 ...

  2. Java 中,类、类对象、泛型之间的转换

    Java 中,类.类对象.泛型之间的转换 R 为非泛型 获得类 通过类型名来获得类 通过对象来获得类 通过类名字符串来获得类 通过类来获得类名字符串 通过类来获得对象 使用 R 的无参数构造器来创建对 ...

  3. Visual Studio各版本工程文件之间的转换 [转载]

    原网址:http://www.cnblogs.com/jmliao/p/5594179.html Visual Studio各版本工程文件之间的转换 由于VS版本比较多,低版本无法直接打开高版本的工程 ...

  4. 计算机视觉:相机成像原理:世界坐标系、相机坐标系、图像坐标系、像素坐标系之间的转换(转载)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/chentravelling/article/details/53558096 0.前言 最近整理了& ...

  5. mysql 数据转换dataset_【转】dataset和实体类 之间的转换

    usingSystem; usingSystem.Collections.Generic; usingSystem.Data; usingSystem.Data.Common; usingSystem ...

  6. 编码与乱码(05)---GBK与UTF-8之间的转换--转载

    原文地址:http://www.blogjava.net/pengpenglin/archive/2010/02/22/313669.html [GBK转UTF-8] 在很多论坛.网上经常有网友问&q ...

  7. C++字符串类型和数字之间的转换

    C++字符串类型和数字之间的转换 转载:http://www.cnblogs.com/luxiaoxun/archive/2012/08/03/2621803.html 1.字符串数字之间的转换 字符 ...

  8. 微信小程序:更改字体(text)和图标(icon)的颜色以及RGB颜色值与十六进制颜色码之间的转换

    摘要: 有时为了让页面小程序页面显示的字体和图标(icon)和顶部导航栏和底部导航栏的颜色相匹配,就需要设置为相同的颜色. 表示颜色的方法 在微信小程序中,用来表示颜色的方法有3种:关键字.RGB.十 ...

  9. PNAS:复杂系统方法定义脑状态:外部刺激促使不同大脑状态之间的转换

    系统神经科学的一个基本问题是:如何通过外部刺激,例如唤醒.睡眠.昏迷或神经精神疾病等因素,促使大脑从一种状态转换到另一种状态.这就需要对大脑状态进行准确的定义,而迄今为止对大脑状态的定义依然是难以确定 ...

最新文章

  1. C++标准库math
  2. 前端面试题整理(js)
  3. 【转】RMAN 高级恢复
  4. matlab球面波衍射,单色点源矩孔菲涅耳衍射光场的计算与模拟
  5. Centos修改主机名,重启后无效解决
  6. php把excel转化为csv,php如何把excel转化为csv
  7. python比较两个数据库表_mysql如何比对两个数据库表结构的方法
  8. java两个对象属性比较
  9. 让 Cloud Native 飞,Pick 干货,看这里、看这里!
  10. 镜头的分类及选购指南
  11. 【意见征集补充】09'博客园T恤设计
  12. android对象缓存,【Android教程】缓存对象中的顶点数组和数据索引
  13. 小程序毕设作品之微信小程序点餐系统毕业设计(1)开发概要
  14. MybatisCodeHelperPro的使用
  15. 如何管理公司的共享iPad?
  16. mysql8初始化 2021-12-18版本 设置mysql大写
  17. vscode管理员身份运行powershell
  18. outlook邮件撤回你了解吗?邮件撤回功能讲解
  19. python plc fx5u_三菱PLC FX5U定位编程时的注意事项说明
  20. 装修颜色搭配大全,全是惊喜啊

热门文章

  1. 用C#开发较完整的Windows任务管理器
  2. windbg调试实例(4)--句柄泄露
  3. 1001 字符串“水”题(二进制,map,哈希)
  4. HTTP请求报文和HTTP响应报文(转载)
  5. PhpCms V9调用指定栏目子栏目文章的两种方法
  6. 在Vista下配置VS2003
  7. 产品经理的思考利器——UML
  8. 如何攻克异地协作难题?看 Tower 的 72 个月远程工作实践
  9. PMCAFF产品经理第一课 | 杭州站 现场集锦
  10. 为什么停车类APP看似缺口巨大却没有成长起来?