首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用datareader填充业务对象的最快方法?

用datareader填充业务对象的最快方法?
EN

Stack Overflow用户
提问于 2011-04-20 18:44:54
回答 4查看 3.7K关注 0票数 2

在DAL中使用datareader填充业务对象的最快、最好和推荐的方法是什么?目前我使用的是

代码语言:javascript
运行
复制
myObject.Name=(string) myDataReader["Name"];
myObject.Age=(int) myDataReader["Age"];

达米恩。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-04-20 20:34:19

为了回答这个问题(而不是推荐一个对象关系模型),最快的方法是您已经用这几行代码演示过的。这些行是非常脆弱的代码,但是如果您取消DbNull检查和TryParse或解析操作,并使用列序号而不是列名,那么代码就不会变得更快或更直接。

当然,如果您打算采用这种方法,那么您最好确保您的数据库代码绝对是防弹的,并且以正确的顺序返回项,并使用适当的值(即,在C#代码中将分配给值类型的列中没有空值)。不用说,这种代码不是很容易长期维护……

票数 4
EN

Stack Overflow用户

发布于 2011-04-20 19:02:32

看一下Dapper项目,它是一个轻量级的对象关系管理实现。

据我所知,它实际上是由(并为) StatOverflow开发的。

票数 3
EN

Stack Overflow用户

发布于 2011-04-20 19:06:33

如果您使用的是数据阅读器,那么除了可以对可能为null的列使用null检查之外,您的方法是一个很好的方法。最快的方法是使用列索引而不是名称。最好的方法是创建一个T4模板,该模板将对某些数据字典(可能是xml文件)进行操作,以便为两种数据字典生成最快的代码并填充这些数据字典。

编辑:哦!-我忘了-推荐的方式是使用一些O/R映射器框架,不要太担心这些平凡的细节!

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5729022

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档