文档章节

Dynamic convert DataTable into entity collectio...

doublefish
 doublefish
发布于 2012/03/16 00:00
字数 367
阅读 197
收藏 2
点赞 0
评论 0


Dynamic convert DataTable into entity collection -- 动态转换数据表成实体集合

在编程中,经常要将查询结果DataTable转换为实体集合,因为每个实体的属性都不一样,所以每个实体都要写专门的转换方法。

如果一个系统中有多个实体,几十上百个,哦,阿门,这种纯体力的劳动,对于作为将编程看作一门艺术的程序猿们,是无法忍受的!?
所以,对于这个在代码和技术含量上,严重影响了我们一行一行敲出来的艺术品的艺术性的问题,我们要解决它!
下面是我的解决办法
涉及技术:反射和泛型。
 

using System; 
using System.Data; 
using System.Reflection; 

namespace DoubleFish.Database 
{ 
    /// < summary> 
     ////// DataTable扩展 
     /// </summary> 
    public static class DataTableExtension 
    { 
        /// <summary>
        /// 将DataTable转换为对应的实体数组 
        /// </summary> 
        public static T[] ToArray(this DataTable dataTable) where T : new() 
        { 
            if (dataTable == null || dataTable.Rows.Count == 0) 
                return new T[] { }; 

            // 定义集合 
            T[] array = new T[dataTable.Rows.Count]; 

            // 获得此模型的类型 
            Type type = typeof(T); 

            T t = new T(); 
            // 获得此模型的公共属性 
            PropertyInfo[] properties = t.GetType().GetProperties(); 

            for (int i = 0; i < dataTable.Rows.Count; i++) 
            { 
                array[i] = new T(); 
                foreach (PropertyInfo pi in properties) 
                { 
                    // 检查DataTable是否包含此列 
                    if (!dataTable.Columns.Contains(pi.Name)) 
                        continue; 

                    // 判断此属性是否有Setter 
                     if (!pi.CanWrite) 
                        continue; 

                    object value = dataTable.Rows[i][pi.Name];
                    if (value == DBNull.Value)
                        continue;

                    pi.SetValue(array[i], value, null);
               }
            }
        }
        return array;
    }
}



还有 ToList(), ToModel 的原理和这个一样,就不贴了。
使用方法:

var ds = DbHelperSQL.Query(strSql, listPara.ToArray());
var array = ds.Tables[0].ToArray(); // DataTable To Array


 


© 著作权归作者所有

共有 人打赏支持
doublefish
粉丝 0
博文 1
码字总数 367
作品 0
合肥
程序员
IBatis.net使用说明

IBatis.net是移植于java版本,所以在.net平台上的操作和java平台上的操作基本没有什么太大的差别。严格来说,ibatis.net并不算的上是一种orm,因为它的sql语句均写到了配置文件中,没有自己专...

JungleKing ⋅ 2016/11/23 ⋅ 0

PrimeFaces 3.0.M3 发布

PrimeFaces是一个用于提高JSF Web应用程序开发效率的开源类库。 PrimeFaces M3 发布了,包含超过 140 项提升,17个新组件,更好的 portlet 支持等等,详细内容: New component: TimeLine Ne...

红薯 ⋅ 2011/08/30 ⋅ 0

C#中List用法

How to find objects in Generics with List.Find() method I've been looking for help on how to find objects in Generics with List.Find() method .... and ... take a look what I hav......

Yong_Luo ⋅ 2010/12/06 ⋅ 0

jquery datatable 常用例子

在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结。 一、DataTable简介 (1)构造函数 ...

wolf_su ⋅ 2013/05/28 ⋅ 0

jquery datatable 常用例子及函数等

在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结。 一、DataTable简介 (1)构造函数 ...

最深的夜 ⋅ 2015/01/26 ⋅ 0

blqw/blqw.Literacy

使用IL.Emit方式快速访问属性,字段和方法 特色 全,易,快 功能强大 上手简单 性能优异 与反射的性能比较 测试1 测试内容 循环次数 运行时间 CPU时钟周期 PropertyInfo.GetValue() 1000000 20...

blqw ⋅ 2016/03/02 ⋅ 0

ADO.NET Code Samples Collection【转载】

原文链接:http://blogs.msdn.com/b/jmeier/archive/2010/10/31/ado-net-code-samples-collection.aspx 版权声明:本文全部版权归原作者所有。 ADO.NET Code Samples Collection J.D. Meier......

56jobs ⋅ 2010/11/19 ⋅ 0

TreeView绑定无限层级关系类

protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { Bind_TV(TreeView1.Nodes); } } region 添加父节点 /// /// 添加父节点 /// /// private void Bind_TV(TreeNod......

随缘不变 ⋅ 2014/04/16 ⋅ 0

杂七杂八——使用LINQ检索重复值

日常工作的时候,我们经常遇到需要检索一组数据中是否有重复值的情况,再根据具体情况进行相应的操作。如果不使用LINQ,那我们就得使用一层一层的foreach循环来做,不但麻烦、工作效率低(因...

余二五 ⋅ 2017/11/16 ⋅ 0

ASP.NET实现类似Excel的数据透视表

代码: /Files/zhuqil/Pivot.zip 数据透视表提供的数据三维视图效果,在Microsoft Excel能创建数据透视表,但是,它并不会总是很方便使用Excel。您可能希望在Web应用程序中创建一个数据透视报...

晨曦之光 ⋅ 2012/03/09 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

如何优雅的编程——C语言界面的一点小建议

我们鼓励在编程时应有清晰的哲学思维,而不是给予硬性规则。我并不希望你们能认可所有的东西,因为它们只是观点,观点会随着时间的变化而变化。可是,如果不是直到现在把它们写在纸上,长久以...

柳猫 ⋅ 15分钟前 ⋅ 0

从零手写 IOC容器

概述 IOC (Inversion of Control) 控制反转。熟悉Spring的应该都知道。那么具体是怎么实现的呢?下面我们通过一个例子说明。 1. Component注解定义 package cn.com.qunar.annotation;impo...

轨迹_ ⋅ 16分钟前 ⋅ 0

系统健康检查利器-Spring Boot-Actuator

前言 实例由于出现故障、部署或自动缩放的情况,会进行持续启动、重新启动或停止操作。它可能导致它们暂时或永久不可用。为避免问题,您的负载均衡器应该从路由中跳过不健康的实例,因为它们...

harries ⋅ 17分钟前 ⋅ 0

手把手教你搭建vue-cli脚手架-详细步骤图文解析[vue入门]

写在前面: 使用 vue-cli 可以快速创建 vue 项目,vue-cli很好用,但是在最初搭建环境安装vue-cli及相关内容的时候,对一些人来说是很头疼的一件事情,本人在搭建vue-cli的项目环境的时候也是...

韦姣敏 ⋅ 28分钟前 ⋅ 0

12c rman中输入sql命令

12c之前版本,要在rman中执行sql语句,必须使用sql "alter system switch logfile"; 而在12c版本中,可以支持大量的sql语句了: 比如: C:\Users\zhengquan>rman target / 恢复管理器: Release 1...

tututu_jiang ⋅ 42分钟前 ⋅ 0

Nginx的https配置记录以及http强制跳转到https的方法梳理

Nginx的https配置记录以及http强制跳转到https的方法梳理 一、Nginx安装(略) 安装的时候需要注意加上 --with-httpsslmodule,因为httpsslmodule不属于Nginx的基本模块。 Nginx安装方法: ...

Yomut ⋅ 58分钟前 ⋅ 0

SpringCloud Feign 传递复杂参数对象需要注意的地方

1.传递复杂参数对象需要用Post,另外需要注意,Feign不支持使用GetMapping 和PostMapping @RequestMapping(value="user/save",method=RequestMethod.POST) 2.在传递的过程中,复杂对象使用...

@林文龙 ⋅ 今天 ⋅ 0

如何显示 word 左侧目录大纲

打开word说明文档,如下图,我们发现左侧根本就没有目录,给我们带来很大的阅读障碍 2 在word文档的头部菜单栏中,切换到”视图“选项卡 3 然后勾选“导航窗格”选项 4 我们会惊奇的发现左侧...

二营长意大利炮 ⋅ 今天 ⋅ 0

智能合约编程语言Solidity之线上开发工具

工具地址:https://ethereum.github.io/browser-solidity/ 实例实验: 1.创建hello.sol文件 2.调试输出结果

硅谷课堂 ⋅ 今天 ⋅ 0

ffmpeg 视频格式转换

转 Mp4 格式 #> ffmpeg -i input.avi -c:v libx264 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 output.mp4#> ffmpeg -i input.avi -c:v libx264 -strict -2 -s 1......

Contac ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部