Mybatis 和 Hibernate 对比

目录

1、Mybatis简介

2、开发对比

(1) 开发速度

(2) 开发社区

(3) 开发工作量

3、系统调优对比

(1) Hibernate

(2) Mybatis

(3) SQL优化

(4) 扩展性

4、对象管理与抓取策略对比

(1) 对象管理

(2) 抓取策略

5、缓存机制对比

6、优势对比

7、Mybatis 和 Hibernate 对比


1、Mybatis简介

        MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。 MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索。 MyBatis 可以使用简单的XML 或注解用于配置和原始映射,将接口和 Java 的 POJO( Plain Old Java Objects,普通的Java 对象)映射成数据库中的记录。

        1)MyBATIS 目前提供了三种语言实现的版本,包括:Java、.NET以及Ruby。(我主要学习java,就讲java的使用)

        2)它提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。

        3)mybatis与hibernate的对比?

        mybatis提供一种“半自动化”的ORM实现。这里的“半自动化”,是相对Hibernate等提供了全面的数据库封装机制的“全自动化”ORM实现而言,“全自动”ORM实现了POJO和数据库表之间的映射,以及 SQL 的自动生成和执行。而mybatis的着力点,则在于POJO与SQL之间的映射关系。

2、开发对比

(1) 开发速度

  • Hibernate的真正掌握要比Mybatis来得难些。

  • Mybatis框架相对简单很容易上手,但也相对简陋些。

(2) 开发社区

  • Hibernate开发社区相对多热闹些,支持的工具也多,更新也快,当前最高版本4.1.8

  • Mybatis相对平静,工具较少,当前最高版本3.2。

(3) 开发工作量

        Hibernate和MyBatis都有相应的代码生成工具,可以生成简单基本的DAO层方法。

        针对高级查询:

  • Mybatis需要手动编写SQL语句,以及ResultMap。

  • Hibernate有良好的映射机制,无需关心SQL的生成与结果映射,可以更专注于业务流程。

3、系统调优对比

(1) Hibernate

  • 制定合理的缓存策略;

  • 尽量使用延迟加载特性;

  • 采用合理的Session管理机制;

  • 使用批量抓取,设定合理的批处理参数(batch_size);

  • 进行合理的O/R映射设计;

(2) Mybatis

        MyBatis在Session方面和Hibernate的Session生命周期是一致的,同样需要合理的Session管理机制。MyBatis同样具有二级缓存机制。 MyBatis可以进行详细的SQL优化设计。

(3) SQL优化

        Hibernate的查询会将表中的所有字段查询出来,这一点会有性能消耗。Hibernate也可以自己写SQL来指定需要查询的字段,但这样就破坏了Hibernate开发的简洁性。而Mybatis的SQL是手动编写的,所以可以按需求指定查询的字段。

        Hibernate HQL语句的调优需要将SQL打印出来,而Hibernate的SQL被很多人嫌弃因为太丑了。MyBatis的SQL是自己手动写的所以调整方便。但Hibernate具有自己的日志统计。Mybatis本身不带日志统计,使用Log4j进行日志记录。

(4) 扩展性

        Hibernate与具体数据库的关联只需在XML文件中配置即可,所有的HQL语句与具体使用的数据库无关,移植性很好。MyBatis项目中所有的SQL语句都是依赖所用的数据库的,所以不同数据库类型的支持不好。

4、对象管理与抓取策略对比

(1) 对象管理

        Hibernate 是完整的对象/关系映射解决方案,它提供了对象状态管理(state management)的功能,使开发者不再需要理会底层数据库系统的细节。也就是说,相对于常见的 JDBC/SQL 持久层方案中需要管理 SQL 语句,Hibernate采用了更自然的面向对象的视角来持久化 Java 应用中的数据。换句话说,使用 Hibernate 的开发者应该总是关注对象的状态(state),不必考虑 SQL 语句的执行。这部分细节已经由 Hibernate 掌管妥当,只有开发者在进行系统性能调优的时候才需要进行了解。而MyBatis在这一块没有文档说明,用户需要对对象自己进行详细的管理。

(2) 抓取策略

        Hibernate对实体关联对象的抓取有着良好的机制。对于每一个关联关系都可以详细地设置是否延迟加载,并且提供关联抓取、查询抓取、子查询抓取、批量抓取四种模式。 它是详细配置和处理的。而Mybatis的延迟加载是全局配置的。

5、缓存机制对比

        Hibernate缓存Hibernate一级缓存是Session缓存,利用好一级缓存就需要对Session的生命周期进行管理好。建议在一个Action操作中使用一个Session。一级缓存需要对Session进行严格管理。Hibernate二级缓存是SessionFactory级的缓存。 SessionFactory的缓存分为内置缓存和外置缓存。内置缓存中存放的是SessionFactory对象的一些集合属性包含的数据(映射元素据及预定SQL语句等),对于应用程序来说,它是只读的。外置缓存中存放的是数据库数据的副本,其作用和一级缓存类似.二级缓存除了以内存作为存储介质外,还可以选用硬盘等外部存储设备。二级缓存称为进程级缓存或SessionFactory级缓存,它可以被所有session共享,它的生命周期伴随着SessionFactory的生命周期存在和消亡。

6、优势对比

        Mybatis优势:

  • MyBatis可以进行更为细致的SQL优化,可以减少查询字段。

  • MyBatis容易掌握,而Hibernate门槛较高。

        Hibernate优势:

  • Hibernate的DAO层开发比MyBatis简单,Mybatis需要维护SQL和结果映射。

  • Hibernate对对象的维护和缓存要比MyBatis好,对增删改查的对象的维护要方便。

  • Hibernate数据库移植性很好,MyBatis的移植性不好,不同的数据库需要写不同SQL。

  • Hibernate有更好的二级缓存机制,可以使用第三方缓存。MyBatis本身提供的缓存机制不佳。

7、Mybatis 和 Hibernate 对比

        两者都基于ORM(对象关系映射,Object Relational Mapping),解决了entity和数据库的映射问题;都只支持JDBC。区别主要有配置、动态SQL(产生移植性问题)、缓存。

        Hibernate是建立在若干POJO通过xml映射文件(或注解)提供的规则映射到数据库表上的。

        Mybatis需要手工匹配提供POJO,sql和映射关系,而全表映射的Hibernate只需要提供pojo和映射关系即可。

        Hibernate为全表映射,使用HQL时每次必须传递所有参数;对于复杂的SQL查询,还是得自己编写SQL,返回查询结果后,需要自己将数据封装为pojo;不能编写动态sql语句,调优要更费力。但是移植性好。

        Mybatis可以配置动态sql,解决了hibernate表名根据时间变化,不同条件下列不一样的问题,同时你也可以对sql进行优化,通过配置决定你的sql映射规则,也能支持存储过程。但是移植性不好。

        Mybatis和Hibernate都可以使用第三方缓存,而hibernate相比mybatis有更好的二级缓存机制。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值