Hibernate主键生成策略

本文记录Java学习过程中遇到的Hibernate主键生成策略~

Hibernate中,提供了几个内置的主键生成策略,常用的主键生成策略的名称和描述如下:

  • increment:用于long、short或者int类型,由Hibernate自动以递增的方式生存唯一标示符,每次增加1。只有当没有其它进程向同一张表中插入数据时才可以使用,不能在集群环境下使用,适用于代理主键;
  • identity:采用底层数据库本身提供的主键生成标识符,条件是数据库支持自动增长数据类型。在DB2、MySQL、SQL Server、Sybase和HypersonicSQL数据库中可以使用该生成器,该生成器要求在数据库中把主键定义成为自增长类型,适用于代理主键;
  • sequence:Hibernate根据底层数据库序列生成标识符,条件是数据库支持序列,例如Oracle,适用于代理主键;
  • hilo:使用hilo生成策略,要在数据库中建立一张额外的表,默认表名为hibernate_unique_key,默认字段为integer类型,名称是next_hi;
  • native:根据底层数据库对自动生成标识符的能力来选择identity、sequence或hilo三种生成器中的一种,适合跨数据库平台开发,适用于代理主键;
  • uuid:Hibernate采用128位的UUID算法来生成标识符,该算法能够在网络环境中生成唯一的字符串标识符,其UUID被编码为一个长度为32位的十六进制字符串。这种策略并不流行,因为字符串类型的主键比整数类型的主键占用更多的数据库空间,适用于代理主键;
  • assigned:由Java程序负责生产标识符,如果不指定ID元素的generrator属性,则默认使用该主键生成策略,适用于自然主键。

标签: none