新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > .Net开发 > Asp.net教程 > 正文:实战 .Net 数据访问层 - 21

实战 .Net 数据访问层 - 21

新客网 XKER.COM 2004-06-20 来源: 收藏本文
(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
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐