当我使用包含大约 100 多个实体的数据源时,我使用了以下方法,这样就不会为每个实体创建存储库。
我的工作主要是只将信息从源保存到我们的数据库。不过也知道如何检索数据。
创建@MappedSuperclass的主要思想:
@MappedSuperclass
public abstract class SuperClass {
@Id
@GeneratedValue
private Integer id;
public SuperClass() {
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
}
然后扩展所有其他实体:
@Entity
public class Class1 extends SuperClass {
private String classInfo;
public String getClassInfo() {
return classInfo;
}
public void setClassInfo(String classInfo) {
this.classInfo = classInfo;
}
@Override
public String toString() {
return "\nClass1{" +
"classInfo='" + classInfo + '\'' +
'}';
}
}
@Entity
public class Class2 extends SuperClass {
private String classInfo;
public String getClassInfo() {
return classInfo;
}
public void setClassInfo(String classInfo) {
this.classInfo = classInfo;
}
@Override
public String toString() {
return "\nClass2{" +
"classInfo='" + classInfo + '\'' +
'}';
}
}
在这种情况下,您的存储库将是:
public interface SuperRepository extends JpaRepository<SuperClass, Integer> {
}
你可以应用它:
Class1 class1 = new Class1();
class1.setClassInfo("Class1 info");
Class2 class2 = new Class2();
class2.setClassInfo("Class2 info");
superRepository.save(class1);
superRepository.save(class2);
//OR
//List<SuperClass> entities = Arrays.asList(class1,class2);
//superRepository.saveAll(entities);
Hibernate 将创建 Class1 和 Class2 表并用数据填充它们。
下一步 - 如何检索数据。
我会考虑这种方法 - 为这个存储库中的每个类创建查询:
public interface SuperRepository extends JpaRepository<SuperClass, Integer> {
@Query("select c from Class1 c")
List<Class1> findAllClass1();
@Query("select c from Class2 c")
List<Class2> findAllClass2();
}
那么当你应用这个时:
System.out.println(superRepository.findAllClass1());
System.out.println(superRepository.findAllClass2());
你会得到:
[Class1{classInfo='Class1 info'}]
[Class2{classInfo='Class2 info'}]