.NET开发

本类阅读TOP10

·NHibernate快速指南(翻译)
·vs.net 2005中文版下载地址收藏
·【小技巧】一个判断session是否过期的小技巧
·VB/ASP 调用 SQL Server 的存储过程
·?dos下编译.net程序找不到csc.exe文件
·通过Web Services上传和下载文件
·学习笔记(补)《.NET框架程序设计(修订版)》--目录
·VB.NET实现DirectDraw9 (2) 动画
·VB.NET实现DirectDraw9 (1) 托管的DDraw
·建站框架规范书之——文件命名

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
实战 .Net 数据访问层 - 21

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

 

(2)    EntityConvert

这个东东是模仿System.Convert的产物,刚开始没觉得咋样,用起来还真有点舍不得呢(本文开头的代码1中曾经使用过这个Utility)!

不信,且看如下代码(仅举两例J):

 

代码16:我变,我变,我变变变!

public static class EntityConvert

{

    public static IList ToList(DbDataReader rdr, Type entity)

    {

       ArrayList list = new ArrayList();

       using (rdr)

       {

           while (rdr.Read())

           {

              object obj = ToObject(rdr, entity, false);

               if (obj != null)

                  list.Add(obj);

           }

       }

       return list;

    }

 

public static object ToObject(DbDataReader rdr,

Type entity, bool bNeedRead)

    {

       object obj = null;

       if (!bNeedRead || rdr.Read())

       {

           // 创建Data Entity对象

           obj = Activator.CreateInstance(entity);

 

           // 设置Data Entity对象之字段数据

           FieldInfo[] fields = entity.GetFields(

BindingFlags.Instance | BindingFlags.Public);

 

           foreach (FieldInfo field in fields)

           {

              string fieldName = field.Name;

               object fieldValue = rdr[fieldName];

 

              if (fieldValue == System.DBNull.Value)

                  field.SetValue(obj, null);

              else

                  field.SetValue(obj, fieldValue);

           }

 

           if (bNeedRead && !rdr.Read())

              rdr.Close();

       }

       return obj;

    }

}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

下一段:http://www.csdn.net/develop/Read_Article.asp?id=27566             




相关文章

相关软件