文档章节

Dynamic convert DataTable into entity collectio...

doublefish
 doublefish
发布于 2012/03/16 00:00
字数 367
阅读 198
收藏 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
合肥
程序员
私信 提问
jquery datatable 常用例子

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

wolf_su
2013/05/28
0
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)构造函数 ...

最深的夜
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

没有更多内容

加载失败,请刷新页面

加载更多

python中sort和sorted函数小结

L.sort(cmp=None, key=None, reverse=False) sorted(iterable, cmp=None, key=None, reverse=False) 这样看,sorted函数只比sort函数多一个iterable参数,其余没什么不同,iterable是一个迭代......

上官夏洛特
29分钟前
1
0
thinkphp 常用SQL执行语句总结

第一条:Db::tablera('vr_panomas')->where(['delete_time'=>0,'id'=>['in',$pids]])->field(['id'=>'id','post_thumb'=>'thumb','post_title'=>'title','post_tags'=>'tags','post_price'=>......

koothon
38分钟前
1
0
支付宝返回状态resultStatus意思

上一篇集成支付宝的时候,会有一些支付宝返回的resultStatus,具体意思是: 9000 订单支付成功 8000 正在处理中 4000 订单支付失败 6001 用户中途取消 6002 网络连接出错 还有memo,意思就是...

RainOrz
42分钟前
1
0
electron webview 页面加载事件顺序

1.did-start-loading 页面开始加载 2.load-commit 主页面文档加载 3.page-title-updated title 4.dom-ready 主页面 dom 加载完成 5.load-commit frame文档加载 6.did-frame-finish-load fram......

dubox
47分钟前
1
0
cron语法格式

Seconds Minutes Hours DayofMonth Month DayofWeek Year或 Seconds Minutes Hours DayofMonth Month DayofWeek...

JavaSon712
48分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部