Hibernate和 MyBatis 的区别有哪些?Hibernate有哪些主键?

Java 的持久层框架产品有许多,常见的有 Hibernate 和 MyBatis。Hibernate是一个开放源代码的对象关系映射框架,可以自动生成SQL语句,自动执行,MyBatis 是一个基于 Java 的持久层框架。它消除了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。那Hibernate和 MyBatis 的区别有哪些?下面来我们就来给大家讲解一下。

1、sql 优化方面

Hibernate 不需要编写大量的 SQL,就可以完全映射,提供了日志、缓存、级联(级联比 MyBatis 强大)等特性,此外还提供 HQL(Hibernate Query Language)对 POJO 进行操作。但会多消耗性能。

MyBatis 手动编写 SQL,支持动态 SQL、处理列表、动态生成表名、支持存储过程。工作量相对大些。

2、开发方面

MyBatis 是一个半自动映射的框架,因为 MyBatis 需要手动匹配 POJO、SQL 和映射关系。

Hibernate 是一个全表映射的框架,只需提供 POJO 和映射关系即可。

3、Hibernate 优势

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

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

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

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

4、Mybatis优势

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

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

Hibernate有哪些主键?

1.Assigned

Assigned方式由用户生成主键值,并且要在save()之前指定否则会抛出异常;

特点:主键的生成值完全由用户决定,与底层数据库无关。用户需要维护主键值,在调用session.save()之前要指定主键值。

2.Hilo

Hilo使用高低位算法生成主键,高低位算法使用一个高位值和一个低位值,然后把算法得到的两个值拼接起来作为数据库中的唯一主键。Hilo方式需要额外的数据库表和字段提供高位值来源。默认情况下使用的表是

hibernate_unique_key,默认字段叫作next_hi。next_hi必须有一条记录否则会出现错误。

特点:需要额外的数据库表的支持,能保证同一个数据库中主键的唯一性,但不能保证多个数据库之间主键的唯一性。Hilo主键生成方式由Hibernate 维护,所以Hilo方式与底层数据库无关,但不应该手动修改hi/lo算法使用的表的值,否则会引起主键重复的异常。

3.Increment

Increment方式对主键值采取自动增长的方式生成新的主键值,但要求底层数据库的主键类型为long,int等数值型。主键按数值顺序递增,增量为1。

特点:由Hibernate本身维护,适用于所有的数据库,不适合多进程并发更新数据库,适合单一进程访问数据库。不能用于群集环境。

4.Identity

Identity方式根据底层数据库,来支持自动增长,不同的数据库用不同的主键增长方式。

特点:与底层数据库有关,要求数据库支持Identity,如MySQl中是auto_increment, SQL Server 中是Identity,支持的数据库有MySql、SQL Server、DB2、Sybase和HypersonicSQL。 Identity无需Hibernate和用户的干涉,使用较为方便,但不便于在不同的数据库之间移植程序。

5.Sequence

Sequence需要底层数据库支持Sequence方式,例如Oracle数据库等;

特点:需要底层数据库的支持序列,支持序列的数据库有DB2、PostgreSql、Oracle、SAPDb等在不同数据库之间移植程序,特别从支持序列的数据库移植到不支持序列的数据库需要修改配置文件。

6.Native

Native主键生成方式会根据不同的底层数据库自动选择Identity、Sequence、Hilo主键生成方式;

特点:根据不同的底层数据库采用不同的主键生成方式。由于Hibernate会根据底层数据库采用不同的映射方式,因此便于程序移植,项目中如果用到多个数据库时,可以使用这种方式。

7.UUID

UUID使用128位UUID算法生成主键,能够保证网络环境下的主键唯一性,也就能够保证在不同数据库及不同服务器下主键的唯一性。特点:能够保证数据库中的主键唯一性,生成的主键占用比较多的存贮空间;

8.Foreign GUID

Foreign用于一对一关系中。GUID主键生成方式使用了一种特殊算法,保证生成主键的唯一性,支持SQL Server和MySQL;

了解Hibernate主键更加有利于我们的开发,另外至于跟MyBatis 的区别,简单的一句就可以概括了,MyBatis 是一个小巧、方便、高效、简单、直接、半自动化的持久层框架,Hibernate 是一个强大、高效、全自动化的持久层框架。最后大家如果想要了解更多java架构师知识,敬请关注奇Q工具网。

推荐阅读:

json对象和json字符串的区别是什么?json字符串如何解析?

qt怎么处理几百兆的json文件?qt如何解析json?

ajax如何实现同步异步?ajax工作原理是什么?