Hibernate&MyBatis different

一、框架介绍

        hibernate是一个优秀的ORM框架(对象关系隐射),高度封装sql语句与表关系,开发者只需要配置好表与pojo类的关系隐射,还有表与表,类与类的多对多,多对一,一对一关系。则开发人员无需sql语句如何编写,把精力放在业务逻辑是。

     mybatis也是一个优秀的ORM框架,不过相对于hibernate来说是比较简陋的,他只是对jdbc的封装,sql语句还有表关系都得自己一一映射。

二、框架使用

        1)hibernate在配置好关系后,可直接对对象进行操作,让使用会话对象的方法实现对数据库的crud操作,而mybatis则需要手动编写sql语句,这样一对比,hibernate的开发速度要优于mybatis,但同时问题也出现了,在面对一些高级查询时,hibernate则是显得有些力不从心了,hibernate的sql语句是写死的,有时候一些字段我们并不需要查询或者修改,但是他封装的是全部,虽然我们可以手动设置字段,但是却破坏了hibernate的简洁性。而mybatis则可以自己手动编写sql进行优化,且有动态sql的功能,可以优化sql.

    2)hibernate有自己的缓存机制,mybatis则没有,而现在大多数都是使用第三方缓存,所以这个优点已被抹去。

    3)hibernate相对来说是重量级的,入门门槛高,而mybatis则是轻量级封装jdbc,可以现学现用。

三、总结

    1)hibernate适合对单表进行操作,不能优化sql,不适合开发高并发的项目,适合OA.CRM等项目的开发。

   2)mybatis的sql语句灵活性,适合互联网项目的开发。


--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

Hibernate的优点:

1、hibernate是全自动,hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。

2、功能强大,数据库无关性好,O/R映射能力强,需要写的代码很少,开发速度很快。

3、有更好的二级缓存机制,可以使用第三方缓存。

4、数据库移植性良好。

5、hibernate拥有完整的日志系统,hibernate日志系统非常健全,涉及广泛,包括sql记录、关系异常、优化警告、缓存提示、脏数据警告等

Hibernate的缺点:

1、学习门槛高,精通门槛更高,程序员如何设计O/R映射,在性能和对象模型之间如何取得平衡,以及怎样用好Hibernate方面需要的经验和能力都很强才行

2、hibernate的sql很多都是自动生成的,无法直接维护sql;虽然有hql查询,但功能还是不及sql强大,见到报表等变态需求时,hql查询要虚,也就是说hql查询是有局限的;hibernate虽然也支持原生sql查询,但开发模式上却与orm不同,需要转换思维,因此使用上有些不方便。总之写sql的灵活度上hibernate不及mybatis。

Mybatis的优点:

1、易于上手和掌握,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

2、sql写在xml里,便于统一管理和优化, 解除sql与程序代码的耦合。

3、提供映射标签,支持对象与数据库的orm字段关系映射

4、 提供对象关系映射标签,支持对象关系组建维护

5、提供xml标签,支持编写动态sql。

6、速度相对于Hibernate的速度较快

Mybatis的缺点:

1、关联表多时,字段多的时候,sql工作量很大。

2、sql依赖于数据库,导致数据库移植性差。

3、由于xml里标签id必须唯一,导致DAO中方法不支持方法重载。

4、对象关系映射标签和字段映射标签仅仅是对映射关系的描述,具体实现仍然依赖于sql。

5、DAO层过于简单,对象组装的工作量较大。

6、不支持级联更新、级联删除。

7、Mybatis的日志除了基本记录功能外,其它功能薄弱很多。

8、编写动态sql时,不方便调试,尤其逻辑复杂时。

9、提供的写动态sql的xml标签功能简单,编写动态sql仍然受限,且可读性低。

猜你喜欢

转载自www.cnblogs.com/Dfrank/p/11653809.html