以下内容是自己遇到:
----------------方式 A ------------------
@javax.persistence.id
@javax.persistence.SequenceGenerator(name="gen1", sequenceName="SEQTEST1")
@javax.persistence.GeneratedValue(generator="gen1", strategy=GenerationType.AUTO)
@javax.persistence.Column(name="ID")
private long getId() { return id; }
----------------方式 B ------------------
@javax.persistence.id
@javax.persistence.SequenceGenerator(name="gen1", sequenceName="SEQTEST1")
@javax.persistence.GeneratedValue(strategy=GenerationType.SEQUENCE, generator="gen1")
@javax.persistence.Column(name="ID")
private long getId() { return id; }
方式B并不使用SEQTEST1, 不知道使用的哪里的sequence,即使删除 了SEQTEST1都不受影响,不明白原因。后换用方式A, 使用了SEQTEST1的值。
以下内容转自:
http://blog.csdn.net/love_xsq/article/details/41962611
@Table(name = "jdps_content")
@SequenceGenerator(name="SEQ_JDPS_content",sequenceName="SEQ_JDPS_CONTENT")
publicclassContent {
@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="SEQ_JDPS_content")
privateintid;
1,这是其中一个实体类,我使用的Oracle的数据库,主键采用oracle的序列,但是问题来了,我发现我的id增长不是以1递增,而是以50递增的,当时我就很纳闷了,后面我就上网查,原来也有人遇到了这个问题,原来是少了allocationSize=1 这个,原来JPA默认的递增大小是50。同时initialValue默认为0,一般都是设置为initialValue=1 修改后的如下所示:@SequenceGenerator(name="SEQ_JDPS_content",allocationSize=1,initialValue=1, sequenceName="SEQ_JDPS_CONTENT")
2,还有一个要注意问题:注解到底是写在 get方法上,还是写在属性上,这个一定要统一,千万不能混淆使用,我推荐写在getter方法上。