使用条件:
当我们进行开发项目时,我们经常会用到实体映射到数据库表的操作,此时我们经常会发现在我们需要映射的几个实体类中,会有共同的属性,例如编号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注解