DataTable操作工具类DataTableHelper
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的更多相关文章
- Code片段 : .properties属性文件操作工具类 & JSON工具类
摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “贵专” — 泥瓦匠 一.java.util.Properties API & 案例 j ...
- [转载]C# FTP操作工具类
本文转载自<C# Ftp操作工具类>,仅对原文格式进行了整理. 介绍了几种FTP操作的函数,供后期编程时查阅. 参考一: using System; using System.Collec ...
- 拼音操作工具类 - PinyinUtil.java
拼音操作工具类,提供字符串转换成拼音数组.汉字转换成拼音.取汉字的首字母等方法. 源码如下:(点击下载 -PinyinUtil.java.pinyin4j-2.5.0.jar ) import net ...
- 【转载】ASP.NET工具类:文件夹目录Directory操作工具类
在ASP.NET开发网站的过程中,有时候会涉及到文件夹相关操作,如判断文件夹目录是否存在.删除文件夹目录.创建文件.删除文件.复制文件夹等等.这一批有关文件目录的操作可以通过Directory类.Fi ...
- Java SE 之 数据库操作工具类(DBUtil)设计
JDBC创建数据库基本连接 //1.加载驱动程序 Class.forName(driveName); //2.获得数据库连接 Connection connection = DriverManager ...
- JavaScript时间操作工具类
/** * 时间操作工具类 * * @author zwq * */ var TimeFrameUtil = { /** * 格式化日期 * @param date {Date} 日期 * @para ...
- java基础37 集合框架工具类Collections和数组操作工具类Arrays
一.集合框架工具类:Collections 1.1.Collections类的特点 该工具类中所有的方法都是静态的 1.2.Collections类的常用方法 binarySearch(List< ...
- 文件操作工具类: 文件/目录的创建、删除、移动、复制、zip压缩与解压.
FileOperationUtils.java package com.xnl.utils; import java.io.BufferedInputStream; import java.io.Bu ...
- JAVA文件操作工具类(读、增、删除、复制)
使用JAVA的JFinal框架 1.上传文件模型类UploadFile /** * Copyright (c) 2011-2017, James Zhan 詹波 (jfinal@126.com). * ...
随机推荐
- 解决 asp.net 伪静态 IIS设置后 直正HTML无法显示的问题
asp.net+UrlRewriter来实现网站伪静态,实现伪静态有一些好处,比如对于搜索引擎更好收录页面,还有一个好处就是隐藏了真实地址的参数,所以有独立服务器的朋友,配置IIS实现伪静态功能,挺不 ...
- 跟我学android-Android应用结构分析(四)
自动生成的R.java文件说明 public final class R { public static final class attr { } public static final class ...
- centos账户的uid和gid
修改/etc/passwd和/etc/group文件的UID和GID为0,可以获得root权限,不过不推荐~ UID和GID Linux系统如何区别不同的用户呢?可以很自然地想到,使用不同的用户名应该 ...
- C++ Primer 5th 第10章 泛型算法
练习10.1:头文件algorithm中定义了一个名为count的函数,它类似find,接受一对迭代器和一个值作为参数.count返回给定值在序列中出现的次数.编写程序,读取int序列存入vector ...
- ORA-00933 UNION 与 ORDER BY
原文:http://blog.csdn.net/lwei_998/article/details/6093807 The UNION operator returns only distinct ro ...
- 如何让你的Python程序支持多语言
如何让你的Python程序支持多语言 本文介绍如何通过Python标准库gettext帮助你的程序支持多语言. 代码例子 import random guessesTaken = 0 print(_( ...
- file upload download
1. 文件上传与下载 1.1 文件上传 案例: 注册表单/保存商品等相关模块! --à 注册选择头像 / 商品图片 (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 文件上传,要点: 前台: ...
- Yii2——MYSQL操作
先创建连接对象 $connection = new \yii\db\Connection([ 'dsn' => $dsn, 'username' => $username, 'passwo ...
- java 代码格式(转)
//转至博客:http://developer.51cto.com/art/201202/320317.ht /** * Java编码格式个人推荐,参考JDK源码和Hyperic HQ源码(原spri ...
- ExtJS5_自定义菜单1
顶部和底部区域已经作好,在顶部区域有一个菜单的按钮,这一节我们设计一个菜单的数据结构,使其可以展示出不同样式的菜单.由于准备搭建的是一个系统模块自定义的系统,因此菜单也是自定义的,在操作员系统登录的时 ...