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");
	 }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值