org.hibernate.query.criteria.internal.BasicPathUsageException: невозможно присоединиться к атрибуту типа basi c - PullRequest
0 голосов
/ 29 февраля 2020

У меня проблема с запросом критериев.

В 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;

Что я сделал неправильно ??? Помогите пожалуйста !!!

1 Ответ

0 голосов
/ 29 февраля 2020

Я сделал это

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> passport = root.join(Guest_.passport);
            query.select(root).where(criteriaBuilder.equal(passport.get(Passport_.COUNTRY),country));
            TypedQuery<Guest> result = entityManager.createQuery(query);
            return result.getResultList();
        } catch (NoResultException e) {
            return null;
        }
    }
...