DataTable操作工具类DataTableHelper。

功能介绍:

  • 将泛型集合填充为数据表
  • 将泛型填充为数据表
  • 将对象集合填充为数据表
  • 将对象填充为数据表
  • 将定IDictionary数据转换为DataSet数据
  • 将数据表填充为泛型集合
  • 将数据表填充为泛型集合
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Reflection;
    using System.Data;
    using System.Collections; namespace IM.Common
    {
    /// <summary>
    /// 数据操作
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    public class DataHelper
    {
    /// <summary>
    /// 将泛型集合填充为数据表
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="list">泛型集合</param>
    /// <param name="tableName">表名</param>
    /// <returns>数据表</returns>
    public static DataTable Fill<T>(IList<T> list, string tableName)
    {
    DataTable dt = new DataTable(tableName);
    T t = Activator.CreateInstance<T>();
    Type type = t.GetType();
    PropertyInfo[] properties = type.GetProperties().Where(p => p.MemberType == MemberTypes.Property && p.CanRead).ToArray();
    foreach (PropertyInfo p in properties)
    {
    dt.Columns.Add(p.Name);
    }
    foreach (T t1 in list)
    {
    PropertyInfo[] properties1 = t1.GetType().GetProperties().Where(p => p.MemberType == MemberTypes.Property && p.CanRead).ToArray();
    DataRow dr = dt.NewRow();
    for (int i = ; i < dt.Columns.Count; i++)
    {
    PropertyInfo propertyInfo = properties1.SingleOrDefault(p => p.Name == Convert.ToString(dt.Columns[i].ColumnName));
    if (propertyInfo != null)
    {
    dr[dt.Columns[i].ColumnName] = propertyInfo.GetValue(t1, null);
    }
    }
    dt.Rows.Add(dr);
    }
    return dt;
    } /// <summary>
    /// 将泛型填充为数据表
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="t">泛型</param>
    /// <param name="tableName">表名</param>
    /// <returns>数据表</returns>
    public static DataTable Fill<T>(T t, string tableName)
    {
    IList<T> list = new List<T>();
    if (t != null)
    {
    list.Add(t);
    }
    return Fill<T>(list, tableName);
    } /// <summary>
    /// 将对象集合填充为数据表
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="list">对象集合</param>
    /// <param name="tableName">表名</param>
    /// <returns>数据表</returns>
    public static DataTable Fill(IList list, string tableName)
    {
    DataTable dt = new DataTable(tableName);
    if (list.Count > )
    {
    PropertyInfo[] properties = list[].GetType().GetProperties().Where(p => p.MemberType == MemberTypes.Property && p.CanRead).ToArray();
    foreach (PropertyInfo p in properties)
    {
    dt.Columns.Add(p.Name);
    }
    foreach (var t in list)
    {
    PropertyInfo[] properties1 = t.GetType().GetProperties().Where(p => p.MemberType == MemberTypes.Property && p.CanRead).ToArray();
    DataRow dr = dt.NewRow();
    for (int i = ; i < dt.Columns.Count; i++)
    {
    PropertyInfo propertyInfo = properties1.SingleOrDefault(p => p.Name == Convert.ToString(dt.Columns[i].ColumnName));
    if (propertyInfo != null)
    {
    dr[dt.Columns[i].ColumnName] = propertyInfo.GetValue(t, null);
    }
    }
    dt.Rows.Add(dr);
    }
    }
    return dt;
    } /// <summary>
    /// 将对象填充为数据表
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="obj">对象</param>
    /// <param name="tableName">表名</param>
    /// <returns>数据表</returns>
    public static DataTable Fill(Object obj, string tableName)
    {
    IList list = null;
    if (typeof(IEnumerable).IsAssignableFrom(obj.GetType()))
    {
    list = (IList)obj;
    }
    else
    {
    list = new ArrayList();
    if (obj != null)
    {
    list.Add(obj);
    }
    }
    return Fill(list, tableName);
    } /// <summary>
    /// 将定IDictionary数据转换为DataSet数据
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="dictionary">键值对数据:key表名,value实体(或实体集合)</param>
    /// <returns>DataSet数据集</returns>
    public static DataSet Fill(IDictionary dictionary)
    {
    DataSet ds = new DataSet();
    foreach (DictionaryEntry de in dictionary)
    {
    DataTable dt = Fill(de.Value, de.Key.ToString());
    ds.Tables.Add(dt);
    }
    return ds;
    } /// <summary>
    /// 将数据表填充为泛型集合
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="dataTable">数据表</param>
    /// <returns>泛型集合</returns>
    public static IList<T> FillList<T>(DataTable dataTable)
    {
    IList<T> list = list = new List<T>();
    if (dataTable != null && dataTable.Rows.Count > && dataTable.Columns.Count > )
    {
    List<string> columnNameList = new List<string>();
    for (int i = ; i < dataTable.Columns.Count; i++)
    {
    columnNameList.Add(dataTable.Columns[i].ColumnName);
    }
    for (int i = ; i < dataTable.Rows.Count; i++)
    {
    DataRow dr = dataTable.Rows[i];
    T t = Activator.CreateInstance<T>();
    Type type = t.GetType();
    PropertyInfo[] properties = type.GetProperties().Where(p => p.MemberType == MemberTypes.Property && p.CanWrite).ToArray();
    foreach (PropertyInfo p in properties)
    {
    if (columnNameList.Contains(p.Name) && dr[p.Name] != DBNull.Value)
    {
    if (p.PropertyType.IsGenericType)
    {
    p.SetValue(t, Convert.ChangeType(dr[p.Name], p.PropertyType.GetGenericArguments()[]), null);
    }
    else
    {
    p.SetValue(t, Convert.ChangeType(dr[p.Name], p.PropertyType), null);
    }
    }
    }
    list.Add(t);
    }
    }
    return list;
    } /// <summary>
    /// 将数据表填充为泛型集合
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/07/26</para>
    /// </summary>
    /// <param name="dataTable">数据表</param>
    /// <returns>泛型集合</returns>
    public static T Fill<T>(DataTable dataTable)
    {
    return FillList<T>(dataTable)[];
    }
    }
    }

DataTable操作工具类DataTableHelper的更多相关文章

  1. Code片段 : .properties属性文件操作工具类 & JSON工具类

    摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “贵专” — 泥瓦匠 一.java.util.Properties API & 案例 j ...

  2. [转载]C# FTP操作工具类

    本文转载自<C# Ftp操作工具类>,仅对原文格式进行了整理. 介绍了几种FTP操作的函数,供后期编程时查阅. 参考一: using System; using System.Collec ...

  3. 拼音操作工具类 - PinyinUtil.java

    拼音操作工具类,提供字符串转换成拼音数组.汉字转换成拼音.取汉字的首字母等方法. 源码如下:(点击下载 -PinyinUtil.java.pinyin4j-2.5.0.jar ) import net ...

  4. 【转载】ASP.NET工具类:文件夹目录Directory操作工具类

    在ASP.NET开发网站的过程中,有时候会涉及到文件夹相关操作,如判断文件夹目录是否存在.删除文件夹目录.创建文件.删除文件.复制文件夹等等.这一批有关文件目录的操作可以通过Directory类.Fi ...

  5. Java SE 之 数据库操作工具类(DBUtil)设计

    JDBC创建数据库基本连接 //1.加载驱动程序 Class.forName(driveName); //2.获得数据库连接 Connection connection = DriverManager ...

  6. JavaScript时间操作工具类

    /** * 时间操作工具类 * * @author zwq * */ var TimeFrameUtil = { /** * 格式化日期 * @param date {Date} 日期 * @para ...

  7. java基础37 集合框架工具类Collections和数组操作工具类Arrays

    一.集合框架工具类:Collections 1.1.Collections类的特点 该工具类中所有的方法都是静态的 1.2.Collections类的常用方法 binarySearch(List< ...

  8. 文件操作工具类: 文件/目录的创建、删除、移动、复制、zip压缩与解压.

    FileOperationUtils.java package com.xnl.utils; import java.io.BufferedInputStream; import java.io.Bu ...

  9. JAVA文件操作工具类(读、增、删除、复制)

    使用JAVA的JFinal框架 1.上传文件模型类UploadFile /** * Copyright (c) 2011-2017, James Zhan 詹波 (jfinal@126.com). * ...

随机推荐

  1. 苹果新政,禁止开发者在App中加入检查更新功能

    今天妥妥的被拒了,苹果更新了新政策,不能在应用中出现检测更新的功能.AppStore会自动提醒用户更新. 去掉更新按钮,之后再尝试下看能通过不能

  2. caption标签,为表格添加标题和摘要

    表格还是需要添加一些标签进行优化,可以添加标题和摘要.代码如下: 摘要 摘要的内容是不会在浏览器中显示出来的.它的作用是增加表格的可读性(语义化),使搜索引擎更好的读懂表格内容,还可以使屏幕阅读器更好 ...

  3. SqlDependency 的使用

    1.SqlDependency是什么: SqlDependency 对象表示应用程序和 SQL Server 实例间的查询通知依赖关系.应用程序可以创建一个 SqlDependency 对象并进行注册 ...

  4. [转载]delete指针之后应该赋值NULL

    首先,C++标准规定:delete空指针是合法的,没有副作用.但是,delete p后,只是释放了指针指向的内存空间.p并不会自动被置为NULL,而且指针还在,同时还指向了之前的地址. 问题来了,对一 ...

  5. TalkingData游戏版本在Cocos2d-x 3.2使用

    最近一直忙别的方面的事情,没有太关注cocos2dx的发展情况,竟然已经更新到了3.2的版本,总的来说3.2比较3.0在使用上会有一些路径的变成,包括ios的引用路径和android上的build的p ...

  6. HTML5 input控件 placeholder属性

    placeholder 属性提供可描述输入字段预期值的提示信息(hint),该提示会在输入字段为空时显示,并会在字段获得焦点时消失. <input placeholder="请输入姓名 ...

  7. PHP错误报告级别及调整方法

    运行PHP脚本时,PHP解析器会尽其所能能报告它遇到的问题.在PHP中错误报告的处理行为,都是通过PHP的配置文件php.ini中有关的配置指令确定的.另外PHP的错误报告有很多种级别,可以根据不同的 ...

  8. Js监控回车事件

    标题通俗的说,也就是绑定当用户按下回车键要执行的事件. 下面,入正题. 第一步,先编写简单的页面代码,这里我们只需要一个按钮就足够了.当然,还有按钮事件. <html> <head& ...

  9. 周赛F题 POJ 1458(最长公共子序列)

    F - F Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u   Description ...

  10. hdu 1241 Oil Deposits(DFS求连通块)

    HDU 1241  Oil Deposits L -DFS Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & ...