实战 .Net 数据访问层 - 21

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

(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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航