主键生成策略
- hibernate的主键生成器:
generator元素:表示了一个主键生成器,它用来为持久化类实例生成唯一的标识 。
1.1 程序员自己控制:assigned
assigned 程序员自己控制表中的主键对应的数据
<!-- <generator class="assigned"></generator> -->
1.2 数据库控制:mysql中: identity(标识列/自动增长)
oracle中: sequence
1.3 hibernate控制:increment uuid/uuid.hex
uuid:随机生成
1.4 其它:native 自动辨别数据库,自动生成
student id int
worker id varchar
<!-- <generator class="uuid"></generator> -->
<!--自定义主键 -->
<!-- <generator class="com.zking.two.id.idCreate"></generator> -->
- 主键生成器要求
2.1 assigned
数据类型不限、保存前必须赋值
2.2 identity(重点掌握)
数字,无需赋值
2.3 sequence(重点掌握)
数字,无需赋值, 默认使hibernate_sequence这个序列,
也可以通过sequence/sequence_name参数赋值
2.4 increment
数字,无需赋值
2.5 uuid/uuid.hex (是由容器自动生成的一个32位的字符串,.hex代表的是十六进制)
32位的字符串,无需赋值,
2.6 native(重点掌握)
等于identity+sequence
- 自定义主键生成器
3.1 *.hbm.xml指定主键生成器类
3.2 创建主键生成器类
实现org.hibernate.id.IdentifierGenerator接口即可,并还可以实现org.hibernate.id.Configurable接口来读取一些配置信息
PersistentIdentifierGenerator.TABLE
PersistentIdentifierGenerator.PK
assigned、native、自定义主键
1、hibernateutil工具类
2、程序员自己控制:assigned
3、数据库控制: identity(标识列/自动增长) sequence
4、hibernate控制:increment uuid/uuid.hex
5、其它native
6、自定义主键生成器
报错
assigned 的错误,必须程序员自己添加id