在DAL中使用datareader填充业务对象的最快、最好和推荐的方法是什么?目前我使用的是
myObject.Name=(string) myDataReader["Name"];
myObject.Age=(int) myDataReader["Age"];达米恩。
发布于 2011-04-20 20:34:19
为了回答这个问题(而不是推荐一个对象关系模型),最快的方法是您已经用这几行代码演示过的。这些行是非常脆弱的代码,但是如果您取消DbNull检查和TryParse或解析操作,并使用列序号而不是列名,那么代码就不会变得更快或更直接。
当然,如果您打算采用这种方法,那么您最好确保您的数据库代码绝对是防弹的,并且以正确的顺序返回项,并使用适当的值(即,在C#代码中将分配给值类型的列中没有空值)。不用说,这种代码不是很容易长期维护……
发布于 2011-04-20 19:02:32
看一下Dapper项目,它是一个轻量级的对象关系管理实现。
据我所知,它实际上是由(并为) StatOverflow开发的。
发布于 2011-04-20 19:06:33
如果您使用的是数据阅读器,那么除了可以对可能为null的列使用null检查之外,您的方法是一个很好的方法。最快的方法是使用列索引而不是名称。最好的方法是创建一个T4模板,该模板将对某些数据字典(可能是xml文件)进行操作,以便为两种数据字典生成最快的代码并填充这些数据字典。
编辑:哦!-我忘了-推荐的方式是使用一些O/R映射器框架,不要太担心这些平凡的细节!
https://stackoverflow.com/questions/5729022
复制相似问题