您的位置:首页 > 数据库

Hibernate主键生成策略

2016-06-10 13:06 267 查看
/**
在所有策略中,只有assigned策略的主键是自己定义的,其余在调用save/persist保存到数据库时会自动生成一个id,所以在这之前设置的id没有意义,其将被覆盖。
正常情况下enhanced-sequence可以满足选择,最好选择pre-insert类型的策略,特殊情况可以自己分配,需要分布式合并数据库可以使用uuid2
*/
/*
*JPA自带三种生成策略
* GenerationType.SEQUENCE:使用数据库序列,若数据库不支持序列则使用表,可与@SequenceGenerator配合使用不同名字的序列
* GenerationType.TABLE:使用数据表来记录序列,可与@TableGenerator配合往表里插入一条新的自增伪序列
* GenerationType.IDENTITY:使用数据库自增长字段,若不存在则出错
* GenerationType.AUTO:自动挑选最佳策略,一般为SEQUENCE/IDENTITY
*/
@Id
@SequenceGenerator(name = "lala",sequenceName = "myseq")
@GeneratedValue(strategy = GenerationType.SEQUENCE,generator = "lala")
//一个实体的主键不能为int型
private long id;

/**
* 使用Hibernate内置的生成策略
* //以下为pre-insert id
* 1.enhanced-sequence:与JPA的SEQUENCE同
* 2.native:同JPA的AUTO
* 3.sequence:只使用数据库的序列,不支持时错误
* 4.enhanced-table:同JPA的TABLE
* 5.seqhilo:高低位算法
* 6.increment:在Hibernate内部产生的自增序列,只适合非集群的环境。
* 7.uuid2:直接在save之前使用UUID生成一个128位的随机0/1序列,用于分布式合并库
* 8.guid:使用数据库生成uuid
* 9.assigned:用户自己生成,可使用uuid自己分配,save时不会被覆盖
* //以下只能在插入时/插入后生成主键,getId可能返回null/0
* 9.sequence-identity:只使用数据库序列,不支持时错误
* 10.identity:同JPA的IDENTITY,不可使用Hibernate注解配置
*/
@Id
@GenericGenerator(name = "eq",strategy = "assigned")
@GeneratedValue(generator = "eq")
private String id;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  hibernate 数据库 jpa