在使用代码生成器的时候,会成生很多不必要的代码.
假设如下环境,自动生成一个查询数据表的存储过程和表的类,使用SqlHelper返回结果
那么在返回表类型的时候一个一个属性的赋值是很麻烦的,这里我们使用反射自动赋值!
如果在存储过程中参数和表列不匹配的将自动调过!
强烈推荐,非常好用!调用如下代码:
/* written by newmin atnet.cc */ public static AClass getaccount(string username) { AClass a = new AClass(); //创建表的实例 OneProdure p = new OneProdureA(); //创建存储过程实例 p.ExecuteNonQuery(); //执行查询,从数据库返回数据赋值给p DataHelper.CloneObjectData<OneProdure, AClass>(p, a); return a; }
东方网新,为您提供专业的网站建设,软件开发,网络营销SEO,网络推广服务,代理国外主机空间,域名注册,服务热线:(+86)18608275575,电子邮件:master#atnet.cc;欢迎您访问东方网新网站:www.atnet.cc
DataHelper.CloneObjectData<T,T>的定义如下:
/* * Author : Newmin www.atnet.cc * Date : 2010/10/27 14:33 */ namespace Atnet.Data { using System; using System.Reflection; using System.Collections.Generic; using System.Text; /// <summary> /// 数据辅助类 /// </summary> public static class DataHelper { /// <summary> /// 拷贝对象的数据 /// </summary> /// <param name="s">包含数据的对象</param> /// <param name="c">要拷贝数据的对象</param> public static void CloneObjectData<SourceType, CloneType>(SourceType s, CloneType c) where SourceType : class { //获取各自的属性 PropertyInfo[] props = typeof(SourceType).GetProperties(); PropertyInfo[] cp = typeof(CloneType).GetProperties(); PropertyInfo _p; foreach (PropertyInfo p in props) { _p = Array.Find(cp, a => string.compare(a.name,p.name,true)==0); if (_p != null) _p.SetValue(c, p.GetValue(s, null), null); } } } }
虽然代码生成器可以减少代码编写量,加上上述的方法更是如此,但还是建议不要使用代码生成器!