JPA @MappedSuperclass子类的不同Id计数器



我有一个@MappedSuperclass,这是我所有实体的基类(@Entity,直接或间接通过多个子类化)。

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@XmlAttribute(required = true)
private Long primaryKey;

生成的Id如上所示。

我的问题是@Id-counter对于每个@Entity都是相同的。事实上,这不是一个大问题,因为它需要一段时间才能达到Long.MAX_VALUE。但达到最大值要容易得多,因为所有实体只有一个计数器。我如何使用不同的@Id-counter而不必将上述代码添加到所有@Entity-classes?

(如果它对你的答案很重要:我使用h2数据库。)

如果您的数据库和表支持AUTO_INCREMENT,请将注释更改为该@Id @GeneratedValue(strategy=GenerationType.IDENTITY)。然后在提交时生成id。

有另一种方法通过TABLE或SEQUENCE策略,但它需要每个Entity显式定义,这是抽象BaseEntity的问题。看一看:

@Entity
@TableGenerator(name="tab", initialValue=0, allocationSize=50)
public class EntityWithTableId {
    @GeneratedValue(strategy=GenerationType.TABLE, generator="tab")
    @Id long id;
}

编辑:嗯,所以这是可能的!MappedSuperclass -更改子类

中的SequenceGenerator
@Id
@Column(name = "ID", unique = true, nullable = false)
@GeneratedValue(strategy = GenerationType.TABLE, generator = "SEQ_AAAAAAAAAAA")
@TableGenerator(
name = "SEQ_AAAAAAAAAAA", 
table = "SEQ_ENTITY" /*<<<==YOUR TABLE NAME FOR SAVE NEXT VALUES HERE*/, 
pkColumnName = "ENTITY", 
initialValue = 1, 
valueColumnName = "NEXT_ID", 
pkColumnValue = "packageee.PACK.PAK.YOURCLASSNAME",     
allocationSize = 1)
private Long id;

相关内容

  • 没有找到相关文章

最新更新