JPA注解-@SequenceGenerator
JPA注解-@SequenceGenerator
无悔这一生 发表于5年前
JPA注解-@SequenceGenerator
  • 发表于 5年前
  • 阅读 12184
  • 收藏 3
  • 点赞 1
  • 评论 1

【腾讯云】买域名送云解析+SSL证书+建站!>>>   

      最近工作中用到了JPA的注解,也是第一次使用JPA的注解。把我在使用的过程中遇到的问题跟大家分享下吧,说的不对的地方,还望大家指出。

第一个问题:示例如下所示

@Entity
@Table(name = "jdps_content")   
@SequenceGenerator(name="SEQ_JDPS_content",sequenceName="SEQ_JDPS_CONTENT") 
public class Content {
	@Id
	@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="SEQ_JDPS_content") 
	private int id;
这是其中一个实体类,我使用的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") 
还有一个要注意问题:注解到底是写在 get方法上,还是写在属性上,这个一定要统一,千万不能混淆使用,我推荐写在getter方法上。
我觉得大家在使用JPA之前,最好还是先看看JPA的文档,那么就不会犯我这样的错误了


  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 6
博文 14
码字总数 8349
评论 (1)
guodefu909
我也遇到这个问题,还好看到你这篇博文,谢谢
×
无悔这一生
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: