文档章节

Dynamic convert DataTable into entity collectio...

doublefish
 doublefish
发布于 2012/03/16 00:00
字数 367
阅读 197
收藏 2


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
12
0
jquery datatable 常用例子

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

wolf_su
2013/05/28
0
0
jquery datatable 常用例子及函数等

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

最深的夜
2015/01/26
1K
0
PrimeFaces 3.0.M3 发布

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

红薯
2011/08/30
638
0
blqw/blqw.Literacy

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

blqw
2016/03/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

git +STS使用问题解决一

1. 2.点以一个pull就是更新代码 3.synchronize workSpace 同步代码,同SVN一致

森火
6分钟前
0
0
powerBi odbc 连接impala 实现自助分析

配置Impala以使用ODBC 可以将第三方产品设计为使用ODBC与Impala集成。为获得最佳体验,请确保支持您打算使用的任何第三方产品。验证支持包括检查Impala,ODBC,操作系统和第三方产品的版本是...

hblt-j
11分钟前
0
0
Purism FAQ

<font size="37" color="#006248" face="幼圆"> <p align="center"> Purism FAQ </p> </font> 原文:https://puri.sm/faq/ 原作者:Purism Team 翻译者:冰焰火灵X 1079092922@qq.com 文章许......

ICE冰焰火灵X
26分钟前
0
0
nginx+webdav

1、配置Nginx以支持WebDav: Webdav是nginx一个组件,默认编译nginx时是没有安装这个组件的。 如果跟应用公用一个nginx,需要重新编译安装nginx,重新安装前需要备份好原来的nginx.conf。 1....

yaukie
32分钟前
0
0
spring 事件

ContextRefreshedEvent Event raised when an {@code ApplicationContext} gets initialized or refreshed. ContextClosedEvent Event raised when an {@code ApplicationContext} gets clos......

Canaan_
43分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部