Hibernate主键生成策略

来源:互联网 发布:java企业项目需求文档 编辑:程序博客网 时间:2024/06/08 11:36
/**在所有策略中,只有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;
0 0
原创粉丝点击