У меня проблема с запросом критериев.
В MySQL базе данных есть человек столбца, и он соединяется с паспортом столбца. С помощью критериев api я пытаюсь получить объект / сущность Person по атрибуту "страна" объекта / объекта Passport.
Пример кода, который я использую:
public List<Guest> getByPassportCountry(String country) {
try {
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<Guest> query = criteriaBuilder.createQuery(Guest.class);
Root<Guest> root = query.from(Guest.class);
Join<Guest, Passport> join = root.join(Guest_.PASSPORT).join(Passport_.COUNTRY);
query.select(root).where(criteriaBuilder.equal(join.get(Passport_.COUNTRY), country));
TypedQuery<Guest> result = entityManager.createQuery(query);
return result.getResultList();
} catch (NoResultException e) {
return null;
}
}
Кроме того, существует связь между этими сущностями: Паспорт сущности
@Entity
@Table(name = "passport_table")
public class Passport extends AEntity{
@Column(name = "passport_serial")
private String passportSerial;
@Column(name = "passport_number")
private Integer passportNumber;
@Column(name = "date_of_issue")
@Convert(converter = StringToDataSQLConverter.class)
private String dateOfIssue;
@Column(name = "date_of_expiry")
@Convert(converter = StringToDataSQLConverter.class)
private String dateOfExpiry;
@Column(name = "country")
private String country;
//One guest to one passport
@OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@JoinColumn(name = "guest_id", referencedColumnName = "id")
private Guest guest;
и Гость сущности
@Entity
@Table(name = "guest_table")
public class Guest extends AEntity {
@Column(name = "guest_first_name", length = 45)
private String guestFirstName;
@Column(name = "guest_last_name", length = 45)
private String guestLastName;
@Column(name = "guest_birthdate")
@Convert(converter = StringToDataSQLConverter.class)
private String guestBirthDate;
//Many guests to one room
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "room_id", referencedColumnName = "id")
private Room room;
//One passport to one guest
@OneToOne(mappedBy = "guest")
private Passport passport;
Что я сделал неправильно ??? Помогите пожалуйста !!!