我在类别和访问者实体之间编写了一个简单的关系OneToMany,
这是我的类别实体:
@Entity
public class Category implements Serializable {
private static final long serialVersionUID = 1L;
private Integer id;
private String name;
private List<Visitor> visitors = new ArrayList<Visitor>();
public Category() {
}
public Category(String name) {
this.name = name;
}
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@OneToMany(fetch = FetchType.EAGER, mappedBy = "category", orphanRemoval = true)
public List<Visitor> getVisitors() {
return visitors;
}
public void setVisitors(List<Visitor> visitors) {
this.visitors = visitors;
}
}
这是我的访客实体:
@Entity
public class Visitor extends User {
private static final long serialVersionUID = 1L;
private String passport;
private String citizenship;
private String gender;
private Company company;
private Category category;
public Visitor() {
}
public Visitor(String email, String firstName, String lastName,
String country, String city, String phoneNumber, String picture,
String passport, String citizenship, String gender, Company company) {
super(email, firstName, lastName, country, city, phoneNumber, picture);
this.passport = passport;
this.citizenship = citizenship;
this.gender = gender;
this.company = company;
}
public String getPassport() {
return passport;
}
public void setPassport(String passport) {
this.passport = passport;
}
public String getCitizenship() {
return citizenship;
}
public void setCitizenship(String citizenship) {
this.citizenship = citizenship;
}
@ManyToOne(fetch = FetchType.LAZY)
public Category getCategory() {
return category;
}
public void setCategory(Category category) {
this.category = category;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
@OneToOne
public Company getCompany() {
return company;
}
public void setCompany(Company company) {
this.company = company;
}
}
即可,但是现在我想要访问我的访问者,我希望每个访问者都有一个完整的类别对象,
但这就是我作为JSON数据所拥有的:
如何解决此问题以获取有关访问者类别的所有信息?
答案 0 :(得分:0)
使用JPQL
select v from Visitor v left join fetch v.category
如果您有重复项,请尝试使用distinct
select distinct v from Visitor v left join fetch v.category