using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Collections;
using System.IO;
using System.Xml.Serialization; namespace HuaTong.General.Utility
{
/// <summary>
/// 数据集处理
/// </summary>
public static class DataTableHandler
{
/// <summary>
/// 检查DataSet是否可用
/// </summary>
public static bool CheckData(this DataSet ds, int valNum)
{
var flag = ds != null && ds.Tables.Count > ;
if (flag)
{
int count = ;
for (var i = ; i < valNum; i++)
{
var dtflag = ds.Tables[i].CheckData();
if (dtflag) count++;
}
return count == valNum;
}
return flag;
} /// <summary>
/// 检查DataTable是否可用
/// </summary>
public static bool CheckData(this DataTable dt)
{
return dt != null && dt.Rows.Count > ;
} /// <summary>
/// 检查DataSet是否可用
/// </summary>
public static DataRow FirstRow(this DataSet ds)
{
return ds.Tables[].FirstRow();
} /// <summary>
/// 检查DataTable是否可用
/// </summary>
public static DataRow FirstRow(this DataTable dt)
{
return dt.Rows[];
} /// <summary>
/// DataTable转换为List
/// </summary>
public static List<T> ToList<T>(this DataTable dt)
where T : new()
{ List<T> list = new List<T>(); foreach (DataRow dr in dt.Rows)
{
T t = dr.ToEntity<T>();
//对象添加到泛型集合中
list.Add(t);
}
return list;
} /// <summary>
/// DataRow转换为实体
/// </summary>
public static T ToEntity<T>(this DataRow dr)
where T : new()
{
if (dr == null)
{
return default(T);
} T model = new T();
var props = ModelHandler.PropCache(model);
for (int i = ; i < dr.Table.Columns.Count; i++)
{
if (props.Any(m => StringHelper.IsEqualString(m.Name, dr.Table.Columns[i].ColumnName)))
{
var prop = props.Single(m => StringHelper.IsEqualString(m.Name, dr.Table.Columns[i].ColumnName));
if (dr[i] != null && dr[i] != DBNull.Value)
{
prop.SetValue(model, Convert.ChangeType(dr[i], prop.PropertyType), null);
}
}
}
return model;
} /// <summary>
/// List转换为DataTable
/// </summary>
public static DataTable ToDataTable<T>(this List<T> items)
{
var tb = new DataTable(typeof(T).Name); PropertyInfo[] props = ModelHandler.PropCache<T>(); foreach (PropertyInfo prop in props)
{
Type t = ModelHandler.GetCoreType(prop.PropertyType);
tb.Columns.Add(prop.Name, t);
} foreach (T item in items)
{
var values = new object[props.Length]; for (int i = ; i < props.Length; i++)
{
values[i] = props[i].GetValue(item, null);
} tb.Rows.Add(values);
} return tb;
} /// <summary>
/// DataTable转换为XML
/// </summary>
public static string ToXML(this DataTable dt)
{
if (!string.IsNullOrEmpty(dt.TableName))
{
dt.TableName = "datatable_1";
}
//xml序列化对象
XmlSerializer xmlSerial = new XmlSerializer(typeof(DataTable));
StringWriter sw = new StringWriter();
xmlSerial.Serialize(sw, dt); // 序列化table
StringReader sr = new StringReader(sw.ToString());
return sr.ReadToEnd();
}
}
}

c# DataTable 数据集处理DataTableHandler的更多相关文章

  1. DataTable数据集转换为List非泛型以及泛型方式

    前言 DataTable是断开式的数据集合,所以一旦从数据库获取,就会在内存中创建一个数据的副本,以便使用.由于在实际项目中,经常会将DataTable中的每行数据转换为Model,然后放到List集 ...

  2. Linq查询datatable的记录集合

    通过linq查询datatable数据集合满足条件的数据集 1.首先定义查询字段的变量,比方深度 string strDepth=查询深度的值: var dataRows = from datarow ...

  3. 【C#常用方法】2.DataTable(或DataSet)与Excel文件之间的导出与导入(使用NPOI)

    DataTable与Excel之间的互导 1.项目添加NPOI的引用 NPOI项目简介: NPOI是一个开源的C#读写Excel.WORD等微软OLE2组件文档的项目,特点是可以在没有安装Office ...

  4. 泛型的运用(用于查询数据后DataTable转实体类)

    2019.8.14 更新 补全了DataTable转泛型集合的方法: /// <summary> /// DataTable转实体类集合 /// </summary> /// ...

  5. MVC3.0----整理之一

    1.ViewBag对象是动态解析对象 @{ ViewBag.Title = "Insert"; } 不仅可以把单个的对象绑定到 ViewBag上,还可以直接绑定List ViewB ...

  6. [C#对Oracle操作]C#操作调用Orcale存储过程有参数

    /// <summary> /// 获取ERP固定资产计提数据 /// </summary> /// <param name="strCompanyCode&q ...

  7. C# 数据操作工具类

    CREATE PROCEDURE [dbo].[RecordFromPage] @SelectList VARCHAR(max), @TableSource VARCHAR(100), @Search ...

  8. table转list

    DataTable数据集转换为List非泛型以及泛型方式 前言 DataTable是断开式的数据集合,所以一旦从数据库获取,就会在内存中创建一个数据的副本,以便使用.由于在实际项目中,经常会将 Dat ...

  9. C# ftp 图片上传多快好省

    前言 此篇讲到的是图片上传功能,每个网站必定会有这样类似的功能,上传文件.上传图片等等.那么接下来,看看我们EF+uploadfile+ftp如何玩转上传图片吧 效果预览 具体实现 一个简单数据库 只 ...

随机推荐

  1. Python面试题之Python中__repr__和__str__区别

    看下面的例子就明白了 class Test(object): def __init__(self, value='hello, world!'): self.data = value >> ...

  2. RabbitMQ学习之(四)_PHP操作RabbitMQ简单Demo

    原理流程 生产者主要做的是:创建连接-->创建channel-->创建交换机对象-->发送消息 消费者主要做的是:创建连接-->创建channel-->创建交换机--&g ...

  3. 20145216史婧瑶《Java程序设计》第2周学习总结

    20145216 <Java程序设计>第2周学习总结 教材学习内容总结 第三章 基础语法 3.1 类型.变量与运算符 •类型 •基本类型 •整数:short(占2字节).int(占4字节) ...

  4. 20145329 《Java程序设计》第三周学习总结

    教材学习内容总结 java并非完整的面向对象程序语言 定义 1:class:定义类 2.char:类型声明变量 3.new:新建对象 4.名称 X:参考 5.=:可用于指定参考至新建变量 6.构造函数 ...

  5. .NET数据库编程求索之路--1.引子

    转载:[ 夏春涛 email: xchuntao@163.com  blog: http://www.cnblogs.com/SummerRain ] 长期做.NET MIS系统开发,打交到最多还是数 ...

  6. 数据结构实习 problem L 由二叉树的中序层序重建二叉树

    由二叉树的中序层序重建二叉树 writer:pprp 用层序中序来重建二叉树 代码点这里 其实本质上与前序中序建立二叉树没有什么太大区别 大概思路: 递归解法,对当前层进行处理,通过层序遍历可以得到当 ...

  7. php redis 秒杀demo

    $redis = new Redis(); $redis->connect("127.0.0.1", "6379"); $redis->select ...

  8. 常见ADB命令

    常见ADB命令 比如说知道了push和pull操作,就可以实现一个简单的手机助手. 如果有多台设备,操作的时候要指定设备.  -s加设备名称

  9. 使用ASP.NET 的缓存机制的示例

    if (HttpContext.Current.Cache["code_" + CodeType] == null) { SysCodeService codeService = ...

  10. SQL 2008R2还原对于服务器失败 备份集中的数据库与现有数据库 3154错误

    以前用sql server 2005的时候就遇到过类似的问题,数据库在别的服务器上备份后,在本机无法还原,这次终于找到了解决方案,网上的没有找到类似的,希望能帮到大家! 原因分析:在SQL Serve ...