Hibernate主键生成器

主键生成器负责生成数据表记录的主键:
increment:为long,short或者int类型主键生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。在集群下不能使用!

identity:在DB2,MySQL,Microsoft SQL Server,Sybase和HypersonicSQL等提供identity(自增长)主键支持的数据表中适用。返回的标识属性是long,short或int类型的

sequence:在DB2,PostgreSQL,Oracle,SAP DB,McKoi等提供sequence支持的数据表中适用。返回的标识属性值是long,short或int类型。

hilo:使用一个高/低位算法高效的生成long,short或int类型的标识符。给定一个表和字段(默认分别是hibernate_unique_key和next_int)作为高位值的来源。高/低位算法生成的标识属性只在一个特定的数据库中是唯一的。

seqhilo:使用一个高/低位算法来高效的生成long,short或int类型的标识符,需要给定一个数据库sequence名。该算法和hilo稍有不同,它将主键历史状态保存在Sequence中,适用于支持Sequence的数据库,如Oracle。

uuid:用一个128位的UUID算法生成字符串类型的标识符,这在一个网路中是唯一的(IP地址也作为算法的数据源)。UUID被编码为一个32位十六进制数的字符串。

<id name="id" column="id" type="string" length="32">
     <generator class="uuid.hex" />
</id>

guid:在Microsoft SQL Server和MySQL中使用数据库生成GUID字符串。

native:根据底层数据库的能力选择identify,sequence或hilo中的一个。

 <id name="id" column="id" type="long">
      <generator class="native" />
 </id>

assigned:让应用程序在save()之前为对象分配一个标识符。这相当于不指定<generator../>元素默认时采用的默认策略。

<id name="id" type="java.lang.String" column="id" length="32" >
      <generator class="assigned" />
</id>

select:通过数据库触发器选择某个唯一主键的行,并返回其主键值作为标识属性值。

foreign:表明直接使用另一个关联对象的标识属性值(即本持久化对象不能生成主键)。

时间: 2024-12-14 18:41:02

Hibernate主键生成器的相关文章

Hibernate主键生成策略总结(转)

Hibernate提供的主键生成策略,使我们可以在实体类的映射xml文件中设定关键字来告诉hibernate我们要使用的主键生成方式,然后hibernate会根据设定完成数据库的主键控制. 一.首先通过举例子来了解实体映射文件(*.hbm.xml)中对id生成策略配置格式 用户User的实体类User.java [java] view plaincopy package com.bjpowernode.hibernate; import java.util.Date; public class 

Hibernate入门(二)之hibernate的内部执行过程,主键生成器,对象的状态

内部执行过程 主键生成器 Identity(常用) 1.表必须支持自动增长机制 2.数据库生成主键 3.不需要在程序中设置主键 Assigned 必须通过程序的方式给值才可以 person.setId(xxx): 一般用于开发的时候测试使用 Increment(常用) 1.如果选择该主键的生成方式,则必须是数字类型 2.先获取主键的最大值,在最大值的基础上加1,形成新的主键 3.效率比较低,因为这种方式会先select表中最大的主键值 4.主键的生成是由hibernate内部实现的 native

hibernate主键的生成器

10-主键的生成器 hibernate是根据映射文件的主键生成器生成主键哒,自己设置的主键不起作用 <!-- 主键的产生器,就该告诉hibernate容器用什么样的方式产生主键--> <generator class="increment"></generator> import org.hibernate.Session; import org.hibernate.Transaction; import org.junit.Test;   publ

Hibernate自定义主键生成器

1:Entity实体配置 2:自定义主键生成器 3:执行save 4:查看结果

[转]hibernate主键生成策略

1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <generator class="assigned" /> </id&g

hibernate主键生成策略

引用:http://www.cnblogs.com/hoobey/p/5508992.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <gene

”伪集群“导致的Hibernate主键increment生成策略异常

一.问题描述: 一个小型WEB应用,单点部署(一份Tomcat+一份MySQL),无集群需求. 有一张数据表的主键使用Hibernate的increment生成策略: <id name="id" column="id"> <generator class="increment" /> </id> 但当有多人在同时调试该表的写入模块时,会抛出如下异常: com.mysql.jdbc.exceptions.jdbc

java框架篇---hibernate主键生成策略

Hibernate主键生成策略 1.自动增长identity 适用于MySQL.DB2.MS SQL Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL Server 和 MySQL 的自增字段,这个方法不能放到 Oracle 中,Oracle 不支持自增字段,要设定sequence(MySQL 和 SQL Server 中很常用) 数据库中的语法如下: MySQL:create table t_user(id int auto_increment

主键生成器

assined 主键的值 程序指定 uuid  hibernate帮你生成uuid,所以主键必须为String Identity 数据库表必须支持自动增长,新的主键的产生是由数据库完成的,并不是由hibernate或者程序员完成的 increment 递增加1 1 <id name="pid" column="pid" length="200" type="java.lang.Long"> 2 <!-- 3