1、increment
对long、int、short的数据列生成自动增长主键。这种情况主要用于数据库中未把表格主键设置为自增,而又想表格主键自增时。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。
这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的键,从而造成主键重复异常。因此,如果同一数据有多个实例(并发量大)访问,此方式必须避免使用。只有在没有其他进程往同一张表中插入数据时才能使用。但是它的生成标识符机制不依赖于底层数据库系统,所以它适合于所有的数据库系统。
2、identity
对如SQL Server 、MySQL等支持自动增长列的数据库,如果数据列的类型时long、short或int,可使用该主键生成器来生成自动增长主键。但是由于它依赖于底层数据库,所以要求底层数据库系统必须支持自动增长字段类型。而且他需要底层数据库把主键定义为自动增长字段类型。
3、native
该生成器依据底层数据库对自动生成标识符的支持能力,来选择使用identity、sequence或hilo标识符生成器。能自动判断底层数据库提供的生成标识符的机制。适合跨平台开发,即同一个Hibernate应用需要连接多种数据库的场合。
4、sequence
对如Oracle、DB2等支持Sequence的数据库,如果数据列的类型时long、short、int,可使用该主键生成器生成自动增长主键。该标识符生成器利用底层数据库提供的序列来生成标识符。
5、uuid.hex
由Hibernate基于128位唯一值产生算法生成16进制数(编码后长度32的字符串表示)作为主键
6、uuid.string
与uuid.hex类似,只是生成的主键未进行编码(长度16).在某些数据库中可能出现问题
7、Assigned
主键由外部程序负责生成,无需Hibernate参与
8、hilo