主键生成策略

  1. 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> -->
  1. 主键生成器要求
    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

  1. 自定义主键生成器
    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