千家信息网

iBATIS与Hibernate间有什么区别

发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,小编给大家分享一下iBATIS与Hibernate间有什么区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!iBATIS与
千家信息网最后更新 2024年09月21日iBATIS与Hibernate间有什么区别

小编给大家分享一下iBATIS与Hibernate间有什么区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

iBATIS与Hibernate间的取舍都是程序员要选择的一个问题,我在最初的选型的时候是打算选择Hibernate 的,在研究的过程中发现了iBATIS,经过分析比较之后我选择了iBATIS。现在我已经使用iBATIS 完成了一个中小型的项目。这个项目在性能、可维护性、可扩展性方面都非常令我满意。

在这个过程中我也不断的与使用过或者正在使用 Hibernate 的人进行过探讨。而且我本身也在不断的跟进 Hibernate 的发展。最终,我的结论是iBATIS 的选择非常正确,而且越用越喜欢它了。当然了,我对 Hibernate 的理解还是非常有限的,所以这里的关于 Hibernate 的一些观点的错误之处希望能够得到 Hibernate 高手的指正。

1.iBATIS易于掌握。

拿来文档看半天到两天就可以掌握了。Hibernate 可能需要 3 倍以上的时间来掌握。

2. iBATIS更容易进行 sql 的 优化。

这个应该大家都有共识了。另外 Hibernate 生成的 sql 也实在是太难看了。鉴于有的朋友提到了 sql 不太重要。我想在这里强调一下我的经验,一般系统性能的瓶颈都在数据库上。所以这一点是iBATIS非常重要的一个优势。

3.iBATIS可以进行细粒度的优化

3.1 比如说我有一个表,这个表有几个或者几十个字段,我需要更新其中的一个字段,iBATIS很简单,执行一个sql UPDATE TABLE_A SET column_1=#column_1# WHERE id=#id# 但是用 Hibernate 的话就比较麻烦了,缺省的情况下Hibernate会更新所有字段。当然我记得Hibernate有一个选项可以控制只保存修改过的字段,但是我不太确定这个功能的负面效果。

3.2 我需要列出一个表的部分内容,用iBATIS 的时候,这里面的好处是可以少从数据库读很多数据,节省流量SELECT ID, NAME FROM TABLE_WITH_A_LOT_OF_COLUMN WHERE ...

3.2.1 一般情况

Hibernate 会把所有的字段都选出来。比如说有一个上面表有8个字段,其中有一两个比较大的字段,varchar(255)/text。上面的场景中我为什么要把他们也选出来呢?

3.2.2 用Hibernate的话,你又不能把这两个不需要的字段设置为 lazy load,因为还有很多地方需要一次把整个 domain object 加载出来。这个时候就能显现出iBATIS的好处了

3.2.3 Hibernate 还有一个方案,就是生成 javabean/map/object[](感谢leelun/cjmm),但是这样的话就可能会产生大量的多余 class。map/object[] 的方式应该不错,我比较喜欢这种方式。

3.3 如果我需要更新一条记录(一个对象),如果使用Hibernate,需要现把对象 select 出来,然后再做 update。这对数据库来说就是两条 sql。而iBATIS只需要一条 update 的 sql 就可以了。减少一次与数据库的交互,对于性能的提升是非常重要。

4. 开发方面

4.1 开发效率上,我觉得两者应该差不多

4.2 可维护性方面,我觉得iBATIS更好一些。因为iBATIS的sql都保存到单独的文件中。而 Hibernate 在有些情况下可能会在 java 代码中保存
sql/hql。

5. 运行效率

5.1 在不考虑 cache 的情况下,iBATIS应该会比Hibernate快一些或者很多(根据实际情况会有所不同)。

当然iBATIS也有比较大的缺点

1. 不同数据库类型的支持不好,如果你要开发的系统是要在对中数据间移植,那可能用Hibernate比较好。

2. 缺省的 cache 支持不好,但是Hibernate的 cache 支持其实也不是很好,而且很复杂。尤其是对于大并发量的应用。所以我更倾向于自己管理 cache。

以上是"iBATIS与Hibernate间有什么区别"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

字段 数据 情况 数据库 选择 重要 内容 性能 方面 时候 篇文章 开发 支持 更新 不同 不好 不断 两个 可维护性 好处 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 临沂市渠成网络技术有限公司 长沙什么软件开发公司比较好 安徽专业服务器机柜云主机 网络技术员是程序员吗 国自然 服务器错误 网络安全法的正式实施日期是 服务器设备信息 战地五怎么和好友一起进服务器 上海南卉互联网科技有限公司 计算机网络技术通信工程师 软件开发项目团队合作 网络安全的正确理解是什么 武汉鑫灵锐网络技术公司 软件开发简历项目职责 设计点赞功能数据库 学校网络安全占信息化比例 数据库读取有字符格式吗 城市交通数据库 单位网络安全责任追究制度 中钞科堡面试软件开发 四川省小学生网络安全知识 qt5线程接收串口数据库 戴尔服务器远程管理 校园网www服务器的ip 数据库删除所有数据命令 c 通用数据库 天津企业党建软件开发系统 网络安全宣传周爱心大使戒指 欧拉推论网络安全计算软件 软件开发的一般流程为
0