MyBatis 和 Hibernate 的相同和不同处,以及实用场景

Mybatis技术特点:

1、  通过直接编写SQL语句,可以直接对SQL进行性能的优化;

2、  学习门槛低,学习成本低。只要有SQL基础,就可以学习mybatis,而且很容易上手;

3、  由于直接编写SQL语句,所以灵活多变,代码维护性更好。

4、  不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。

5、  需要编写结果映射。

Hibernate技术特点:

1、 标准的orm框架,程序员不需要编写SQL语句。

2、  具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。

3、  学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。

4、  程序员不能自主的去进行SQL性能优化。

 

Mybatis应用场景:

         需求多变的互联网项目,例如电商项目。试用需求,变化固定中小型项目;ERP,ORM,OA

Hibernate应用场景:

         需求明确、业务固定的项目,例如OA项目、ERP项目等。 互联网项目; 敏捷开发。

               当希望对象的持久化对应用程序完全透明是,不适合使用mybatis
               当数据库有移植需求或需要支持多种数据库时,不适合使用mybatis

映射关系描述:

hibernate: 对数据库结构提供了较为完整的封装,hibernate O/R Mapping实现了POJO 和数据库表之间的映射,以及SQL 的自动生成和执行。

只需定义好了POJO 到数据库表的映射关系,即可通过提供的方法完成持久层操作。

不需要对SQL 的熟练掌握, 会根据制定的存储逻辑,自动生成对应的SQL 并调用JDBC 接口加以执行。 

mybatis:POJO SQL之间的映射关系。然后通过映射配置文件,将SQL所需的参数,以及返回的结果字段映射到指定POJO。 相对O/R”而言,iBATIS 是一种“Sql Mapping”的ORM实现。

数据库的无关性:

hibernate 的 具体数据只需要利用xml 进行关联; HQL 语句与数据库无关

mybatis 更接近sql ,因此对数据库的依赖较多。

 

 

Mybatis优势

    MyBatis可以进行更为细致的SQL优化,可以减少查询字段。
    MyBatis容易掌握,而Hibernate门槛较高。

Hibernate优势

    Hibernate的DAO层开发比MyBatis简单,Mybatis需要维护SQL和结果映射。
    Hibernate对对象的维护和缓存要比MyBatis好,对增删改查的对象的维护要方便。
    Hibernate数据库移植性很好,MyBatis的数据库移植性不好,不同的数据库需要写不同SQL。
    Hibernate有更好的二级缓存机制,可以使用第三方缓存。MyBatis本身提供的缓存机制不佳


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值