使用条件:
当我们进行开发项目时,我们经常会用到实体映射到数据库表的操作,此时我们经常会发现在我们需要映射的几个实体类中,会有共同的属性,例如编号ID,创建者,创建时间,修改者,修改时间,备注等。遇到这种情况,我们可能会想到把这些属性抽象出来当成一个父类,然后再以不同的实体类来继承这个父类。
那么,我们便可以使用@MappedSuperclass注解

通过这个注解,我们可以将该实体类当成基类实体,它不会映射到数据库表,

继承它的子类实体在映射时会自动扫描该基类实体的映射属性,添加到子类实体的对应数据库表中。

 1 /*
 2 * 泛化:继承关系
 3 * 告诉JPA这是所有类都继承的父类
 4 * */
 5 @MappedSuperclass
 6 public class BaseDomain {
 7     @Id
 8     @GeneratedValue
 9     protected Long id;
10 
11     public Long getId() {
12         return id;
13     }
14 
15     public void setId(Long id) {
16         this.id = id;
17     }
18 }

  子类:

 1 @Entity
 2 @Table(name = "department")
 3 public class Department extends BaseDomain {
 4     private String name;
 5 
 9     public String getName() {
10         return name;
11     }
12 
13     public void setName(String name) {
14         this.name = name;
15     }24 }

 

使用环境:

1.@MappedSuperclass注解使用在父类上面,是用来标识父类的作用

2.@MappedSuperclass标识的类表示其不能映射到数据库表,因为其不是一个完整的实体类,但是它所拥有的属性能够映射在     其子类对用的数据库表中

3.@MappedSuperclass标识得类不能再有@Entity或@Table注解  但是可以使用@Id 和@Column注解