When I worked with a datasource with about 100+ entities I used the following method so that do not create repositories for each entity.
I worked mainly for only saving information from the source to our database. However have some idea how to retrieve data also.
The main idea to create @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;
}
}
Then extends all other entities:
@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 + '\'' +
'}';
}
}
Your repository in this case will be:
public interface SuperRepository extends JpaRepository<SuperClass, Integer> {
}
And you can apply it:
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 will create Class1 and Class2 tables and fill them with data.
The next step - how to retrieve the data.
I would think about such method - create queries for each class in this one repository:
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();
}
Then when you apply this:
System.out.println(superRepository.findAllClass1());
System.out.println(superRepository.findAllClass2());
you will get:
[Class1{classInfo='Class1 info'}]
[Class2{classInfo='Class2 info'}]