Как отделить ключевой общий класс для сущностей, использующих JPA и Hibernate?
У меня есть общие свойства для моих классов Entity. У них должен быть Id - последовательность long
числоDate
createDate, который показывает, когда кортеж сущности добавляется в БД и Date
Свойство lastModifiedDate, которое показывает, когда была сделана последняя модификация кортежа.
Я использую JPA 2.1.,Hibernate 4.3.6.Final
<depedencies>
<!-- Hibernate -->
<dependency>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.1-api</artifactId>
<version>1.0.0.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>5.1.1.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.3.6.Final</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.34</version>
</dependency>
</dependencies>
Итак, я создал общий класс с ключевыми свойствами:
@Embeddable
public class AbstractArticle implements Serializable {
private static final long serialVersionUID = 895868474989692116L;
@Nonnull
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(nullable = false)
private long id;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "createdDate", nullable = false)
private Date createdDate;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "lastModifiedDate", nullable = false)
private Date lastModifiedDate;
public AbstractArticle() {
}
... //getters and setters
}
и другой класс, который использует значения этого общего ключа
@Entity
public class BBCNews{
@Nonnull
@Column(name = "newsId", nullable = false)
private long newsId;
@Nonnull
@Column(name = "title", nullable = false)
private String title;
@CheckForNull
@Column(name = "description", nullable = true)
private String description;
@Id
private AbstractArticle abstractArticle;
public BBCNews() {
}
...//getters and setters
Хорошо, все было в порядке, но длинный идентификатор AbstractArticle был одинаковым 0, все кортежи в БД были с 0 в качестве идентификатора. Какова польза от этого? Есть идеи?
1 ответ
Решение
Использование наследования может быть?
@MappedSuperclass
public abstract class AbstractArticle implements Serializable { /* ... */ }
@Entity
public class BBCNews extends AbstractArticle { /* ... */ }