精华内容
下载资源
问答
  • 5. MyBatis Hibernate 有哪些不同?
    2022-02-06 20:39:09

    1、Mybatis 和 hibernate 不同,它不完全是一个 ORM 框架,因为 MyBatis 需要 程序员自己编写 Sql 语句。

    2、Mybatis 直接编写原生态 sql,可以严格控制 sql 执行性能,灵活度高,非常 适合对关系数据模型要求不高的软件开发,因为这类软件需求变化频繁,一但需 求变化要求迅速输出成果。但是灵活的前提是 mybatis 无法做到数据库无关性, 如果需要实现支持多种数据库的软件,则需要自定义多套 sql 映射文件,工作量大。

    3、Hibernate 对象/关系映射能力强,数据库无关性好,对于关系模型要求高的 软件,如果用 hibernate 开发可以节省很多代码,提高效率。

    更多相关内容
  • 主要介绍了Mybatis与Hibernate区别与用途的相关资料,需要的朋友可以参考下
  • mybatis与hibernate区别

    2021-09-18 15:30:26
    hibernate 市场占用率 高 高 适合的行业 互联网、电商、项目 传统的(ERP、CRM、OA) 性能、及其控制 高、性能好控制 低、性能不好控制 Sql灵活性 高 低 学习门槛(成本) ...

     一 对比表格

    对比项mybatis       hibernate
    市场占用率
    适合的行业互联网、电商、项目传统的(ERP、CRM、OA)
    性能、及其控制高、性能好控制低、性能不好控制
    Sql灵活性
    学习门槛(成本)
    sql配置全局配置文件、映射文件全局配置文件、映射文件
    映射文件包含定义POJO、配置SQL和映射关系(规则)。mybatis仅有基本的字段映射,对象数据以及对象实际关系仍然需要通过手写sql来实现和管理。只需要提供POJO并配置映射关系便可
    ORM半自动化,不是一个完整的ORM框架完全的自动化,是一个完整的ORM框架
    sql语句编写需要自己去写全部SQL常规CRUD我们不需要写一句SQL
    数据库无关性
    自动建表功能不能自动建表可以自动建表
    可移植性不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。Mysql:limit、Oracle:rownum,需要编写结果映射。移植性好。具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。以后,mysql数据迁移到oracle,只需要改方言配置
    对存储过程的支持支持不能有效支持存储过程
    dao层的开发Mybatis需要维护SQL和结果映射。mybatis主要着力点在于java对象与SQL之间的映射关系。针对高级查询,Mybatis需要手动编写SQL语句,以及ResultMap。Hibernate的DAO层开发比MyBatis简单。而Hibernate有良好的映射机制,开发者无需关心SQL的生成与结果映射,可以更专注于业务流程。
    日志系统Mybatis的日志除了基本记录功能外,其它功能薄弱很多,所以要借助log4j来记录日志。hibernate拥有完整的日志系统,hibernate日志系统非常健全,涉及广泛,包括sql记录、关系异常、优化警告、缓存提示、脏数据警告等
    级联删除、更新不支持级联更新、级联删除支持

    二  与JDBC关系

    Hibernate是在JDBC上进行了一次封装。

    Mybatis是基于原生的JDBC的。Mybatis有运行速度上的优势。

    三 查询区别

    ·1、简单查询:

            Hibernate 提供了基础的查询方法,也可以根据具体的业务编写相应的SQL;

            Mybatis需要手动编写SQL语句;

            Spring Data 继承基础接口,可使用内置的增删改查方法。

    2、高级查询:

            Hibernate通过对象映射机制,开发者无需关心SQL的生成与结果映射,专注业务流程;

            Mybatis需要通过手动在XML文件中编写SQL语句以及ResultMap或者注解;

            Spring Data 提供了命名规范查询和注解查询更简便的编写想要的SQL。

    四 查询方式

    1、Hibernate查询:
            1.HQL  --->from Admin as admin where admin.name =:name 使用命名参数,仅使用与Hiberante框架

            2.Criteria---->对象化查询 

                      Criteria c = getSession().Criteria(Admin.class)

                      c.add(Restrictions.eq("aname",name));//eq是等于,gt是大于,lt是小于,or是或
                      c.add(Restrictions.eq("apassword", password));

            3.DetachedCriteria----->动态分离查询

            4.例子查询-Example.create(user).list()

            5.sql查询

                    Query q = s.createSQLQuery("select * from user").addEntity(User.class);

            6.命名查询:Query q = getSession().getNamedQuery(“getUserByID”);


    2、Mybatis查询:

            定义xml例如;userMapper.xml

            定义接口userMapper 定义相关的方法 不必编写接口的实现类

            通过mybatis内部处理机制解析xml文件中的sql 

            调用存储过程 {call 存储过程名}


    3、Spring Data查询:

            1.命名查询,需要遵循Spring Data规范,例如findByUser、deleteById 等从右向左解析生成sql

            2.注解查询:@Query(“ql语句”)

    五 事务

            Hibernate和MyBatis都支持JDBC和JTA事务处理。

    六 性能(优化)

    1、mybatis

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

    2、hibernate

    (1)学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。程序员不能自主的去进行SQL性能优化。

    (2)对多表关联和复杂SQL查询支持较差,需要自己写SQL,返回后,需要自己将数据组装为POJO
    (3)虽然有HQL,但是性能较差, 大型互联网系统往往需要优化SQL,而hibernate做不到

    七 系统调优对比

    1、 Hibernate的调优方案

    1. 制定合理的缓存策略;

    2. 尽量使用延迟加载特性;

    3. 采用合理的Session管理机制;

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

    5. 进行合理的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进行日志记录。

            总的来说,Hibernate使用的是封装好,通用的SQL来应付所有场景,而Mybatis是针对响应的场景设计的SQL。Mybatis的SQL会更灵活、可控性更好、更优化。

    4、扩展性方面

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

    八 对象管理与抓取策略

    1、对象管理

            Hibernate 是完整的对象/关系映射解决方案,它提供了对象状态管理(state management)的功能,使开发者不再需要理会底层数据库系统的细节。也就是说,相对于常见的 JDBC/SQL 持久层方案中需要管理 SQL 语句,Hibernate采用了更自然的面向对象的视角来持久化 Java 应用中的数据。

            换句话说,使用 Hibernate 的开发者应该总是关注对象的状态(state),不必考虑 SQL 语句的执行。这部分细节已经由 Hibernate 掌管妥当,只有开发者在进行系统性能调优的时候才需要进行了解。

            而MyBatis在这一块没有文档说明,用户需要对对象自己进行详细的管理。

    2、抓取策略

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

            而Mybatis的延迟加载是全局配置的。

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

    1、Hibernate缓存        

            Hibernate一级缓存是Session缓存,利用好一级缓存就需要对Session的生命周期进行管理好。建议在一个Action操作中使用一个Session。一级缓存需要对Session进行严格管理。

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

    2、mybatis缓存

            MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。MyBatis 3 中的缓存实现的很多改进都已经实现了,使得它更加强大而且易于配置。

            默认情况下是没有开启缓存的,除了局部的 session 缓存,可以增强变现而且处理循环 依赖也是必须的。要开启二级缓存,你需要在你的 SQL 映射文件中添加一行:  <cache/>

    字面上看就是这样。这个简单语句的效果如下:

    1. 映射语句文件中的所有 select 语句将会被缓存。

    2. 映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。

    3. 缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。

    4. 根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。

    5. 缓存会存储列表集合或对象(无论查询方法返回什么)的 1024 个引用。

    6. 缓存会被视为是 read/write(可读/可写)的缓存,意味着对象检索不是共享的,而 且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。

    所有的这些属性都可以通过缓存元素的属性来修改。

    比如: <cache  eviction="FIFO"  flushInterval="60000"  size="512"  readOnly="true"/>

    这个更高级的配置创建了一个 FIFO 缓存,并每隔 60 秒刷新,存数结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改它们会 导致冲突。可用的收回策略有, 默认的是 LRU:

    1. LRU – 最近最少使用的:移除最长时间不被使用的对象。

    2. FIFO – 先进先出:按对象进入缓存的顺序来移除它们。

    3. SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。

    4. WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。

    flushInterval(刷新间隔)可以被设置为任意的正整数,而且它们代表一个合理的毫秒 形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新。

    size(引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的 可用内存资源数目。默认值是1024。

    readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓 存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。可读写的缓存 会返回缓存对象的拷贝(通过序列化) 。这会慢一些,但是安全,因此默认是 false。

    3、相同点

            Hibernate和Mybatis的二级缓存除了采用系统默认的缓存机制外,都可以通过实现你自己的缓存或为其他第三方缓存方案,创建适配器来完全覆盖缓存行为。

    4、不同点

            Hibernate的二级缓存配置在SessionFactory生成的配置文件中进行详细配置,然后再在具体的表-对象映射中配置是那种缓存。

            MyBatis的二级缓存配置都是在每个具体的表-对象映射中进行详细配置,这样针对不同的表可以自定义不同的缓存机制。并且Mybatis可以在命名空间中共享相同的缓存配置和实例,通过Cache-ref来实现。

    5、两者比较

            因为Hibernate对查询对象有着良好的管理机制,用户无需关心SQL。所以在使用二级缓存时如果出现脏数据,系统会报出错误并提示。

            而MyBatis在这一方面,使用二级缓存时需要特别小心。如果不能完全确定数据更新操作的波及范围,避免Cache的盲目使用。否则,脏数据的出现会给系统的正常运行带来很大的隐患。

    十 数据库移植性

            Mybatis由于所有SQL都是依赖数据库书写的,所以扩展性,迁移性比较差。

            Hibernate与数据库具体的关联都在XML中,所以HQL对具体是用什么数据库并不是很关心。

    十一 功能、特性丰富程度

       Hibernate提供了诸多功能和特性。要全掌握很难。

       Mybatis 自身功能很有限,但Mybatis支持plugin,可以使用开源的plugin来扩展功能。

    十二 动态SQL

       Mybatis mapper xml 支持动态SQL

       Hibernate不支持

    十三 总结:实际项目关于Hibernate和Mybatis的选型:

    1. 数据量:有以下情况最好选用Mybatis

      如果有超过千万级别的表;

      如果有单次业务大批量数据提交的需求(百万条及以上的),这个尤其不建议用Hibernate

      如果有单次业务大批量读取需求(百万条及以上的)(注,hibernate多表查询比较费劲,用不好很容易造成性能问题);

    2. 表关联复杂度

      如果主要业务表的关联表超过20个(大概值),不建议使用hibernate

    3. 人员

      如果开发成员多数不是多年使用hibernate的情况,建议使用mybatis

    4. 数据库对于项目的重要程度

      如果项目要求对于数据库可控性好,可深度调优,用mybatis

    十四 参考

    1、mybatis_录播_02mybatis介绍 - 程序员大本营 https://www.pianshen.com/article/81181120626/

    2、对比JPA 和Hibernate 和 Mybatis的区别 - 十五小哥哥 - 博客园 (cnblogs.com) https://www.cnblogs.com/wanghj-15/p/11182334.html

    3、(35条消息) mybatis与hibernate的区别持久层对比【面试题】_weixin_30765577的博客-CSDN博客  https://blog.csdn.net/weixin_30765577/article/details/98264678 

    4、HIbernate和Mybatis的区别和优劣势_慕课手记 (imooc.com)  https://www.imooc.com/article/27839?block_id=tuijian_wz

    5、(35条消息) Spring Data JPA、 MyBatis与Hibernate简单对比_weixin_34186950的博客-CSDN博客 https://blog.csdn.net/weixin_34186950/article/details/93297682

    6、Mybatis与Hibernate的详细对比_136.la  https://www.136.la/java/show-38441.html

    7、【持久化框架】Mybatis与Hibernate的详细对比 - 割肉机 - 博客园 (cnblogs.com) https://www.cnblogs.com/williamjie/p/9198987.html

    8、MyBatis和Hibernate的优缺点对比。-CSDN社区 https://bbs.csdn.net/topics/397417231?list=17589243

    9、 (35条消息) Hibernate与Mybatis的区别与联系_放牛班的春夏秋冬的博客-CSDN博客 https://blog.csdn.net/weixin_46110257/article/details/103763515

    10、hibernate和mybatis对比分析_java_脚本之家 (jb51.net) https://www.jb51.net/article/123588.htm

    11、(35条消息) MyBatis与Hibernate区别_eff666的博客-CSDN博客_mybatis和hibernate的区别  https://blog.csdn.net/eff666/article/details/71332386

    12、Mybatis与传统jdbc和Hibernate的比较 - 程序员小污 (hugr.cn) https://hugr.cn/2019/12/28/mybatis%E4%B8%8E%E4%BC%A0%E7%BB%9Fjdbc%E5%92%8Chibernate%E7%9A%84%E6%AF%94%E8%BE%83/

    13、(不只有理论,还深入到实际应用中代码层的对比)(35条消息) 总结传统JDBC以及MyBatis和Hibernate的对比_难再晨的博客-CSDN博客_jdbc和mybatis区别  https://blog.csdn.net/zwg_html/article/details/56033935  

    展开全文
  • MyBatis与Hibernate区别

    万次阅读 多人点赞 2017-05-07 16:03:27
    1、概述hibernatemybatis是当前流行的ORM框架。hibernate对数据库结构提供了较为完整的封装。mybatis主要着力点在于java对象SQL之间的映射关系。2、Hibernate理解Hibernate是一个开放源代码的对象关系映射框架,...

    1、概述

    hibernate和mybatis是当前流行的ORM框架。hibernate对数据库结构提供了较为完整的封装。mybatis主要着力点在于java对象与SQL之间的映射关系。

    2、Hibernate理解

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将java对象与数据库表建立映射关系,是一个全自动的orm框架。

    Hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用。我们从三个角度理解一下Hibernate:

    (1)Hibernate是对JDBC进一步封装

    原来没有使用Hiberante做持久层开发时,存在很多冗余,如:各种JDBC语句,connection的管理,所以出现了Hibernate把JDBC封装了一下,我们不用操作数据,直接操作它就行了。

    (2)从分层的角度来看

    我们知道非常典型的三层架构:表示层,业务层,还有持久层。Hiberante也是持久层的框架,而且持久层的框架还有很多,比如:IBatis,Nhibernate,JDO,OJB,EJB等等。

    (3)Hibernate是开源的一个ORM(对象关系映射)框架

    ORM,即Object-Relational Mapping,它的作用就是在关系型数据库和对象之间做了一个映射。从对象(Object)映射到关系(Relation),再从关系映射到对象。这样我们在操作数据库的时候,不需要再去和复杂SQL打交道,只要像操作对象一样操作它就可以了(把关系数据库的字段在内存中映射成对象的属性)。

    简单来说,hibernate就是将对象数据保存到数据库,将数据库数据读入到对象中。

    3、Hibernate的核心
    这里写图片描述

    从上图中,我们可以看出Hibernate六大核心接口,两个主要配置文件,以及他们直接的关系。Hibernate的所有内容都在这了。那我们从上到下简单的认识一下,每个接口进行一句话总结。

    //Configuration接口:负责配置并启动Hibernate
    //SessionFactory接口:负责初始化Hibernate
    //Session接口:负责持久化对象的CRUD操作
    //Transaction接口:负责事务
    //Query接口和Criteria接口:负责执行各种数据库查询

    注意:Configuration实例是一个启动期间的对象,一旦SessionFactory创建完成它就被丢弃了。

    4、使用hibernate存在的原因

    (1)JDBC操作数据库很繁琐
    (2)SQL语句编写并不是面向对象
    (3)可以在对象和关系表之间建立关联来简化编程
    (4)ORM简化编程
    (5)ORM跨越数据库平台

    5、Hibernate的优/缺点

    5.1 优点

    (1)不需要编写的SQL语句(不需要编辑JDBC),只需要操作相应的对象就可以了,就可以能够存储、更新、删除、加载对象,可以提高生产效

    (2)使用Hibernate,移植性好(只要使用Hibernate标准开发,更换数据库时,只需要配置相应的配置文件就可以了,不需要做其它任务的操作)

    (3)Hibernate实现了透明持久化。当保存一个对象时,这个对象不需要继承Hibernate中的任何类、实现任何接口,只是个纯粹的单纯对象—称为POJO对象(最纯粹的对象—这个对象没有继承第三方框架的任何类和实现它的任何接口)

    (4)Hibernate是一个没有侵入性的框架,没有侵入性的框架我们一般称为轻量级框架

    (5)Hibernate代码测试方便

    (6)有更好的二级缓存机制,可以使用第三方缓存

    5.2 缺点

    (1)使用数据库特性的语句,将很难调优
    (2)对大批量数据更新存在问题
    (3)系统中存在大量的攻击查询功能
    (4)缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。

    6、MyBatis

    (1)入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

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

    (3)缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。

    (4)二级缓存机制不佳。

    7、Hibernate与MyBatis对比

    7.1 相同点

    Hibernate与MyBatis都可以是通过SessionFactoryBuider由XML配置文件生成SessionFactory,然后由SessionFactory 生成Session,最后由Session来开启执行事务和SQL语句。

    其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。Hibernate和MyBatis都支持JDBC和JTA事务处理。

    7.2 不同点

    (1)hibernate是全自动,而mybatis是半自动

    hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。而mybatis仅有基本的字段映射,对象数据以及对象实际关系仍然需要通过手写sql来实现和管理。

    (2)hibernate数据库移植性远大于mybatis

    hibernate通过它强大的映射结构和hql语言,大大降低了对象与数据库(Oracle、MySQL等)的耦合性,而mybatis由于需要手写sql,因此与数据库的耦合性直接取决于程序员写sql的方法,如果sql不具通用性而用了很多某数据库特性的sql语句的话,移植性也会随之降低很多,成本很高。

    (3)hibernate拥有完整的日志系统,mybatis则欠缺一些

    hibernate日志系统非常健全,涉及广泛,包括:sql记录、关系异常、优化警告、缓存提示、脏数据警告等;而mybatis则除了基本记录功能外,功能薄弱很多。

    (4)mybatis相比hibernate需要关心很多细节

    hibernate配置要比mybatis复杂的多,学习成本也比mybatis高。但也正因为mybatis使用简单,才导致它要比hibernate关心很多技术细节。mybatis由于不用考虑很多细节,开发模式上与传统jdbc区别很小,因此很容易上手并开发项目,但忽略细节会导致项目前期bug较多,因而开发出相对稳定的软件很慢,而开发出软件却很快。hibernate则正好与之相反。但是如果使用hibernate很熟练的话,实际上开发效率丝毫不差于甚至超越mybatis。

    (5)sql直接优化上,mybatis要比hibernate方便很多

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

    (6)缓存机制上,hibernate要比mybatis更好一些

    MyBatis的二级缓存配置都是在每个具体的表-对象映射中进行详细配置,这样针对不同的表可以自定义不同的缓存机制。并且Mybatis可以在命名空间中共享相同的缓存配置和实例,通过Cache-ref来实现。

    而Hibernate对查询对象有着良好的管理机制,用户无需关心SQL。所以在使用二级缓存时如果出现脏数据,系统会报出错误并提示。

    8、总结

    (1)两者相同点
    Hibernate和Mybatis的二级缓存除了采用系统默认的缓存机制外,都可以通过实现你自己的缓存或为其他第三方缓存方案,创建适配器来完全覆盖缓存行为。

    (2)两者不同点
    Hibernate的二级缓存配置在SessionFactory生成的配置文件中进行详细配置,然后再在具体的表-对象映射中配置是那种缓存。而MyBatis在使用二级缓存时需要特别小心。如果不能完全确定数据更新操作的波及范围,避免Cache的盲目使用。否则,脏数据的出现会给系统的正常运行带来很大的隐患。

    (3)举个形象的比喻

    MyBatis:机械工具,使用方便,拿来就用,但工作还是要自己来作,不过工具是活的,怎么使由我决定。(小巧、方便、高效、简单、直接、半自动)

    Hibernate:智能机器人,但研发它(学习、熟练度)的成本很高,工作都可以摆脱他了,但仅限于它能做的事。(强大、方便、高效、复杂、绕弯子、全自动)

    展开全文
  • mybatis与hibernate区别

    2016-08-20 09:33:36
    随着使用熟练度的增加,发现它与hibernate区别是非常大的,结合至今为止的经验,总结出以下几点: 1. hibernate是全自动,而mybatis是半自动。 hibernate完全可以通过对象关系模型实现对数据库的操作,拥有...


    以前没怎么用过mybatis,只知道与hibernate一样是个orm数据库框架。随着使用熟练度的增加,发现它与hibernate区别是非常大的,结合至今为止的经验,总结出以下几点:

    1. hibernate是全自动,而mybatis是半自动。

    hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。而mybatis仅有基本的字段映射,对象数据以及对象实际关系仍然需要通过手写sql来实现和管理。

    2. hibernate数据库移植性远大于mybatis。

    hibernate通过它强大的映射结构和hql语言,大大降低了对象与数据库(oracle、MySQL等)的耦合性,而mybatis由于需要手写sql,因此与数据库的耦合性直接取决于程序员写sql的方法,如果sql不具通用性而用了很多某数据库特性的sql语句的话,移植性也会随之降低很多,成本很高。

    3. hibernate拥有完整的日志系统,mybatis则欠缺一些。

    hibernate日志系统非常健全,涉及广泛,包括:sql记录、关系异常、优化警告、缓存提示、脏数据警告等;而mybatis则除了基本记录功能外,功能薄弱很多。

    4. mybatis相比hibernate需要关心很多细节

    hibernate配置要比mybatis复杂的多,学习成本也比mybatis高。但也正因为mybatis使用简单,才导致它要比hibernate关心很多技术细节。mybatis由于不用考虑很多细节,开发模式上与传统jdbc区别很小,因此很容易上手并开发项目,但忽略细节会导致项目前期bug较多,因而开发出相对稳定的软件很慢,而开发出软件却很快。hibernate则正好与之相反。但是如果使用hibernate很熟练的话,实际上开发效率丝毫不差于甚至超越mybatis。

    5. sql直接优化上,mybatis要比hibernate方便很多

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


    总结:

    mybatis:小巧、方便、高效、简单、直接、半自动

    hibernate:强大、方便、高效、复杂、绕弯子、全自动


    mybatis:

    1. 入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

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

    3. 缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。

    4. 二级缓存机制不佳。

    hibernate:

    1. 功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。

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

    3. 缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。

    举个形象的比喻:

    mybatis:机械工具,使用方便,拿来就用,但工作还是要自己来作,不过工具是活的,怎么使由我决定。

    hibernate:智能机器人,但研发它(学习、熟练度)的成本很高,工作都可以摆脱他了,但仅限于它能做的事。

    以前没怎么用过mybatis,只知道与hibernate一样是个orm数据库框架。随着使用熟练度的增加,发现它与hibernate区别是非常大的,结合至今为止的经验,总结出以下几点:

    1. hibernate是全自动,而mybatis是半自动。

    hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。而mybatis仅有基本的字段映射,对象数据以及对象实际关系仍然需要通过手写sql来实现和管理。

    2. hibernate数据库移植性远大于mybatis。

    hibernate通过它强大的映射结构和hql语言,大大降低了对象与数据库(oracle、MySQL等)的耦合性,而mybatis由于需要手写sql,因此与数据库的耦合性直接取决于程序员写sql的方法,如果sql不具通用性而用了很多某数据库特性的sql语句的话,移植性也会随之降低很多,成本很高。

    3. hibernate拥有完整的日志系统,mybatis则欠缺一些。

    hibernate日志系统非常健全,涉及广泛,包括:sql记录、关系异常、优化警告、缓存提示、脏数据警告等;而mybatis则除了基本记录功能外,功能薄弱很多。

    4. mybatis相比hibernate需要关心很多细节

    hibernate配置要比mybatis复杂的多,学习成本也比mybatis高。但也正因为mybatis使用简单,才导致它要比hibernate关心很多技术细节。mybatis由于不用考虑很多细节,开发模式上与传统jdbc区别很小,因此很容易上手并开发项目,但忽略细节会导致项目前期bug较多,因而开发出相对稳定的软件很慢,而开发出软件却很快。hibernate则正好与之相反。但是如果使用hibernate很熟练的话,实际上开发效率丝毫不差于甚至超越mybatis。

    5. sql直接优化上,mybatis要比hibernate方便很多

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


    总结:

    mybatis:小巧、方便、高效、简单、直接、半自动

    hibernate:强大、方便、高效、复杂、绕弯子、全自动


    mybatis:

    1. 入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

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

    3. 缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。

    4. 二级缓存机制不佳。

    hibernate:

    1. 功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。

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

    3. 缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。

    举个形象的比喻:

    mybatis:机械工具,使用方便,拿来就用,但工作还是要自己来作,不过工具是活的,怎么使由我决定。

    hibernate:智能机器人,但研发它(学习、熟练度)的成本很高,工作都可以摆脱他了,但仅限于它能做的事。

    展开全文
  • struts2介绍、和springmvc对比,mybatis介绍和hibernate对比
  • MyBatis与Hibernate有哪些不同?

    千次阅读 2021-01-19 11:23:25
    1)Mybatishibernate不同,它不完全是一个ORM框架,因为MyBatis需要程序员自己编写Sql语句,不过mybatis可以通过XML或注解方式灵活配置要运行的sql语句,并将java对象和sql语句映射生成最终执行的sql,最后将sql...
  • mybatishibernate区别

    2019-09-19 15:18:49
    hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的javaBean对象数据库的映射结构来自动生成sql。而mybatis仅有基本的字段映射,对象数据以及对象实际关系仍然需要通过手写sql来实现和管理。 2....
  • Mybatis与Hibernate区别

    2019-04-04 16:17:41
    随着使用熟练度的增加,发现它与hibernate区别是非常大的,结合至今为止的经验,总结出以下几点: 1) hibernate是全自动,而mybatis是半自动。 hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整...
  • Mybatis与Hibernate区别

    2020-09-02 21:30:06
    以前没怎么用过mybatis,只知道hibernate一样是个orm数据库框架。随着使用熟练度的增加,发现它与hibernate区别是非常大的感兴趣的朋友通过本文一起学习吧
  • Mybatis 与hibernate

    2021-03-15 09:05:15
    (1)Hibernate与MyBatis都是通过SessionFactoryBuider由XML配置文件生成SessionFactory,由SessionFactory 生成Session,由Session来开启执行事务和SQL(Structured Query Language,结构化查询语言)语句。...
  • MyBatisHibernate区别

    2020-12-08 19:15:25
    1、hibernate是全自动,hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象数据库的映射结构来自动生成sql。 2、功能强大,数据库无关性好,O/R映射能力强,需要写的代码很少,开发...
  • 面试题:mybatishibernate区别1 相同点2 不同点(1)hibernate是全自动,而mybatis是半自动(2)hibernate数据库移植性远大于mybatis(3)hibernate拥有完整的日志系统,mybatis则欠缺一些(4)mybatis相比...
  • springboot(4) 整合mybatishibernate 请删除项目中本地仓库的配置,或者改成国内的公共仓库,否则将无法启动

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 66,966
精华内容 26,786
关键字:

mybatis与hibernate的区别