JPA主键

以下内容是自己遇到:

----------------方式 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方法上。

猜你喜欢

转载自springwind.iteye.com/blog/2405892