ADO.NET、NBear和NHibernate和IbatisNet简单读写性能比较

 http://www.cnblogs.com/try/archive/2007/07/25/830718.html


下载测试示例程序(运行前请先参看压缩包里的说明文件:初始数据和修改数据库链接)

测试代码基于Teddy的ADO.NET、NBear和NHibernate简单读写性能比较中的测试代码修改.

主要修改:
1.ADO.NET的测试使用microsoft的SqlHelper.
2.测试引用的版本分别为:NBear V3.7.2.4,IBatisNet V1.6.1,NHibernate1.0.1.0 for net1.1
3.使用Stopwatch计时

说明(引用原Teddy测试一文):
本测试使用Northwind数据库的Categories、Customers和Products三个表(初始数据每个表1000条数据),测试比较ADO.NET、NBear和NHibernate的读写性能。公平起见,测试代码并没有使用太多特别框架的独有功能或缓存,在实际测试前分别都进行了预读(保证元数据等都在第一次运行时已载入)。

读测试每次循环分别读取Categories、Customers和Products三个表的全部数据,三个组件分别返回DataSet,强类型实体数组和IList,虽然返回的数据类型不同,但是,实际上都包括了对返回数据的填充操作,因此,应该是相对公平的。3个ORM对Product表数据列表都使用了1对1形式(即Product信息中包含Category信息)
结果显示NBear的性能近似于ADO.NET;NHibernate的独性能要差5倍左右。

写测试每次循环分别新建、更新并删除Categories、Customers和Products三个表中的各一条记录。ADO.NET由于是直接执行SQL的,速度最快是肯定的。 NBear相比ADO.NET慢约3倍,NHibernate则大约慢2倍。

鉴于一般的系统读操作的频率远高于写操作, NBear的平均性能应该要比NHibernate好处不少。

测试并不完全,仅作参考。测试代码如有错误,请指正.

我的测试结果:nbear性能最差.(和teddy测试差距很大.黑灰色底为原Teddy测试结果)
程序以console方式运行,Release编译.运行3次.以第3次为结果.


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值