原文地址:http://www.javaworld.com/article/2077875/open-source-tools/ibatis--hibernate--and-jpa--which-is-right-for-you-.html?page=7
关于iBATIS, Hibernate, and JPA 的性能以及什么场景下使用,其实争论是不小的,为什么呐,因为各有各的特点,各有各的喜好!现在就这几种技术
做个简单的比较,比较如下:
1. 比较持久化技术
现在你已经检查了三个不同的持久化机制及其操作。每个框架都有自己的优点和缺点。让我们考虑几个参数,将帮助你决定最好的选择其中适合你的要求。
2. 简单
在许多应用领域的发展,时间是一个重要的约束,尤其是当团队成员需要训练使用一个特定的框架。在这种情况下,iBatis是最好的选择。这是最简单的三个框架,因为它只需要了解SQL。
3. 完整的ORM解决方案
像Hibernate的ORM解决方案与传统JPA 应该用于杠杆完成对象关系映射。Hibernate的Java对象直接与jpa地图数据库表映射Java对象,而ibatis 对于result SQL查询。在一些应用中,对于复杂的业务逻辑。在这样的场景,ibatis 是正确的选择。
4. 依赖的SQL
一直有人谁是在界定之间的井工和谁是舒适的在Java和SQL。Java程序员是谁不想使用的持久层框架Hibernate和SQL的多相互作用,是最好的选择,它在运行时生成有效的SQL查询。然而,如果你想完全控制在数据库中使用存储过程,然后查询,ibatis是推荐的解决方案。也支持通过JPA SQL createnativequery()方法.
5.支持的查询语言
iBATIS的匹配SQL很好,而Hibernate JPA使用自己的查询语言(SQL jpql和,分别为),这是类似于SQL的。
6.性能
应用程序必须执行为了成功。Hibernate的缓存提高性能提供设施,帮助更快的检索数据库中的数据。iBATIS使用SQL查询可以微调,以获得更好的性能。JPA的性能取决于供应商的实现。选择是每个应用程序。
7. 适用不同关系数据库.
有时,你将需要改变,你的应用程序使用关系数据库。如果你使用你的hibernate 持久化的解决方案,那么这个问题是容易分辨,它使用数据库配置文件。从一个数据库支撑另一个单线程的数据库值改变。hibernate使用关系映射得到sql去操作数据库。
ibatis需要你写你自己的SQL代码;因此,一个 iBATIS应用的需要自己定义 SQL。如果使用SQL查询,然后ibatis 手写在不同的关系数据库。jpa是不同的实现,像hibernate和CCK的要领。所以,如果供应商没有特异功能被使用在程序中,可移植性成为为琐碎的问题。
8. 社区的支持和文档8.
Hibernate是这方面的一个明确的赢家。有许多Hibernate聚焦论坛成员积极响应查询。ibatis和JPA正在慢慢在这方面。
9. 在非Java平台的可移植性
iBATIS支持.Net 和 Ruby在 Rails.。Hibernate提供了一个持久的解决方案。网NHibernate的形式。作为一个Java API JPA,具体,显然不支持任何非Java平台。
这种比较是总结在表1。
10. 持久化对比:
Features | iBATIS | Hibernate | JPA |
---|---|---|---|
Simplicity | Best | Good | Good |
Complete ORM solution | Average | Best | Best |
Adaptability to data model changes | Good | Average | Average |
Complexity | Best | Average | Average |
Dependence on SQL | Good | Average | Average |
Performance | Best | Best | N/A * |
Portability across different relational databases | Average | Best | N/A * |
Portability to non-Java platforms | Best | Good | Not Supported |
Community support and documentation | Average | Good | Good |
11.结论
iBATIS,Hibernate,和JPA是在关系数据库中存储数据的三种不同的机制。每一种都有其优点和局限性。iBATIS不能提供一个完整的ORM解决方案,并且不提供任何直接的映射对象和关系模型。然而,iBatis为你提供结束查询完整的控制。Hibernate提供了一个完整的ORM解决方案,但提供你没有控制权的查询。Hibernate是非常流行的和一个大的和活跃的社区,提供了新的用户支持。JPA还提供了一个完整的ORM解决方案,并提供了面向对象编程的特征如继承和多态性支持,但其性能取决于持久性提供者。
一个特定的持久化机制的选择是一个权衡所有的文章比较部分讨论的特点。对于大多数开发人员决定将根据您是否需要在SQL应用程序的完全控制,需要自动生成SQL,或只是想要一个简单的程序完整的ORM解决方案。
到底使用什么框架,使用什么持久化方案,其实没有一个定论,完全是由实际的应用来决定!不过,给人觉得:mybatis是做持久化的首选,是最好的解决方案!!!