hibernate:主键生成策略

1.assigned

程序员自己控制:不受数据库的影响(sid自增长也没用,得程序员自己定义)

<generator class="assigned"></generator>

数据类型不限、保存前必须赋值

2.identity(sql数据库)

数据库控制: (sql数据库)identity(标识列/自动增长)
数据库控制:受数据库影响 sid自增长 , sid的数据类型必须为数字 ,无需赋值

3.sequence(oracle数据库)

数据库控制:sequence(oracle数据库)
数据库控制:受数据库影响 sid自增长 , sid的数据类型必须为数字 ,无需赋值
默认使hibernate_sequence这个序列,
也可以通过sequence/sequence_name参数赋值

4.hibernate控制:increment uuid/uuid.hex

increment :
由hibernate自动递增的方式生成标识符,每次增量为1,优点是适用于所有数据库,缺点是在集群环境下可能会出现相同的主键值且OID必须为数值类型
uuid/uuid.hex
(是由容器自动生成的一个32位的字符串,.hex代表的是十六进制)
32位的字符串,无需赋值
OID是String类型而不能是数值类型

5.其它:native

等于identity+sequence
由Hibernate根据底层数据库自行判断采用identity,sequence其中一种作为主键生成方式。

6.创建主键生成器类

实现org.hibernate.id.IdentifierGenerator接口即可,并还可以实现org.hibernate.id.Configurable接口来读取一些配置信息

public class MyIdCreate implements IdentifierGenerator{
  	 public Serializable generate(SharedSessionContractImplementor session, Object object) throws HibernateException {
	  //公司名_模块名_时间戳  
	  return "zking_order_"+new SimpleDateFormat("YY-MM-DD hh:mm:ss");
	 }
}

猜你喜欢

转载自blog.csdn.net/qq_40973475/article/details/83245091