Спецификация не работает правильно с CriteriaBuilder.and () - PullRequest
0 голосов
/ 26 сентября 2018

У меня есть следующая структура базы данных База данных

И я использую Spring Boot 2.0.5

Все экзамены имеют один pupil_measure, который имеет много calc_values.Это calc_values ​​имеет строку с типом "102" и значением ("-1","0","1","2")

Мне нужно найти все экзамены, которые имеют calc_value с типом "102" равно "2"

Итак, в чистом SQLя сделал следующий запрос, и он работает довольно хорошо

select e from examination e
         join pupil_measure m2 on e.id = m2.examination
         join calc_value v on m2.id = v.measure
    where v.type=102 and v.value=2

Но проблема в том, чтобы использовать метод CruDRepository findAll () с JpaSpecifications

public interface ExaminationRepository 
       extends CrudRepository<Examination,UUID>, 
               JpaSpecificationExecutor<Examination> {}

У меня есть следующая спецификация

public static Specification<Examination> resEq(final String exp){
    return (r,cq,cb)-> cb.and(    
cb.equal(r.join("pupilMeasuresById").join("calcValues").get("type"),102),
cb.equal(r.join("pupilMeasuresById").join("calcValues").get("value"),2D));
}

И когда я делаю это

examinationRepository.findAll(resEq())

Я получаю список экзаменов, который содержит экзамены со значениями 1 и 0

Что я делаю неправильно?

Экзаменационная организация

@Entity
public class Examination {
    private UUID id;
    private Timestamp ts;
    private Integer status;
    private Integer number;
    private String comment;
    private Boolean issynthetic;
    @JsonManagedReference
    private Collection<AlcoMeasure> alcoMeasuresById;
    @JsonBackReference
    private Collection<BinaryPath> binaryPathsById;
    @JsonManagedReference
    private Patient patientByPatient;
    @JsonManagedReference
    private Terminal terminalByTerminal;
    @JsonBackReference
    private Collection<OxygenMeasure> oxygenMeasuresById;
    @JsonBackReference
    private Collection<PressureMeasure> pressureMeasuresById;
    @JsonManagedReference
    private Collection<PupilMeasure> pupilMeasuresById;
    @JsonBackReference
    private Collection<WeightMeasure> weightMeasuresById;
    @JsonBackReference
    private Set<EGroup> groups=new HashSet<>();
    @JsonBackReference
    private Set<Answer> answers=new HashSet<>();

    @Id
    @Column(name = "id")
    public UUID getId() {
        return id;
    }

    public void setId(UUID id) {
        this.id = id;
    }

    @Basic
    @Column(name = "ts")
    public Timestamp getTs() {
        return ts;
    }

    public void setTs(Timestamp ts) {
        this.ts = ts;
    }

    @Basic
    @Column(name = "status")
    public Integer getStatus() {
        return status;
    }

    public void setStatus(Integer status) {
        this.status = status;
    }

    @Basic
    @Column(name = "number")
    public Integer getNumber() {
        return number;
    }

    public void setNumber(Integer number) {
        this.number = number;
    }

    @Basic
    @Column(name = "comment")
    public String getComment() {
        return comment;
    }

    public void setComment(String comment) {
        this.comment = comment;
    }

    @Basic
    @Column(name = "issynthetic")
    public Boolean getIssynthetic() {
        return issynthetic;
    }

    public void setIssynthetic(Boolean issynthetic) {
        this.issynthetic = issynthetic;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Examination that = (Examination) o;
        return Objects.equals(id, that.id) &&
                Objects.equals(ts, that.ts) &&
                Objects.equals(status, that.status) &&
                Objects.equals(number, that.number) &&
                Objects.equals(comment, that.comment) &&
                Objects.equals(issynthetic, that.issynthetic);
    }

    @Override
    public int hashCode() {

        return Objects.hash(id, ts, status, number, comment, issynthetic);
    }

    @OneToMany(mappedBy = "examination")
    public Collection<AlcoMeasure> getAlcoMeasuresById() {
        return alcoMeasuresById;
    }

    public void setAlcoMeasuresById(Collection<AlcoMeasure> 
alcoMeasuresById) {
        this.alcoMeasuresById = alcoMeasuresById;
    }

    @OneToMany(mappedBy = "examination")
    public Collection<BinaryPath> getBinaryPathsById() {
        return binaryPathsById;
    }

    public void setBinaryPathsById(Collection<BinaryPath> binaryPathsById) {
        this.binaryPathsById = binaryPathsById;
    }

    @ManyToOne
    @JoinColumn(name = "patient", referencedColumnName = "id", nullable = 
false)
    public Patient getPatientByPatient() {
        return patientByPatient;
    }

    public void setPatientByPatient(Patient patientByPatient) {
        this.patientByPatient = patientByPatient;
    }

    @ManyToOne
    @JoinColumn(name = "terminal", referencedColumnName = "id")
    public Terminal getTerminalByTerminal() {
        return terminalByTerminal;
    }

    public void setTerminalByTerminal(Terminal terminalByTerminal) {
        this.terminalByTerminal = terminalByTerminal;
    }


    @OneToMany(mappedBy = "examination")
    public Collection<OxygenMeasure> getOxygenMeasuresById() {
        return oxygenMeasuresById;
    }

    public void setOxygenMeasuresById(Collection<OxygenMeasure> 
oxygenMeasuresById) {
        this.oxygenMeasuresById = oxygenMeasuresById;
    }

    @OneToMany(mappedBy = "examination")
    public Collection<PressureMeasure> getPressureMeasuresById() {
        return pressureMeasuresById;
    }

    public void setPressureMeasuresById(Collection<PressureMeasure> 
pressureMeasuresById) {
        this.pressureMeasuresById = pressureMeasuresById;
    }

    @OneToMany(fetch = FetchType.LAZY, mappedBy = "examination")
    @JsonIgnore
    public Collection<PupilMeasure> getPupilMeasuresById() {
        return pupilMeasuresById;
    }

    public void setPupilMeasuresById(Collection<PupilMeasure> 
pupilMeasuresById) {
        this.pupilMeasuresById = pupilMeasuresById;
    }

    @OneToMany(mappedBy = "examination")
    public Collection<WeightMeasure> getWeightMeasuresById() {
        return weightMeasuresById;
    }

    public void setWeightMeasuresById(Collection<WeightMeasure> 
weightMeasuresById) {
        this.weightMeasuresById = weightMeasuresById;
    }

    @ManyToMany(cascade = {CascadeType.ALL})
    @JoinTable(
            name="examination_answers",
            joinColumns = {@JoinColumn(name="examination")},
            inverseJoinColumns = {@JoinColumn(name = "answer")}
    )
    public Set<Answer> getAnswers() {
        return answers;
    }

    public void setAnswers(Set<Answer> answers) {
        this.answers = answers;
    }

    @ManyToMany(cascade = {CascadeType.ALL})
    @JoinTable(
            name="examination_group",
            joinColumns = {@JoinColumn(name="examination")},
            inverseJoinColumns = {@JoinColumn(name = "group")}
    )

    public Set<EGroup> getGroups() {
        return groups;
    }

    public void setGroups(Set<EGroup> groups) {
        this.groups = groups;
    }


}

pupil_measure Entity

@Entity
@Table(name = "pupil_measure", schema = "public", catalog = "newmed")
public class PupilMeasure {
    private UUID id;
    private Timestamp ts;
    private Boolean isFail;
    private Integer flags;
    @JsonManagedReference
    private Collection<CalcValue> calcValues;
    @JsonBackReference
    private Examination examination;

    @Id
    @Column(name = "id")
    public UUID getId() {
        return id;
    }

    public void setId(UUID id) {
        this.id = id;
    }

    @Basic
    @Column(name = "ts")
    public Timestamp getTs() {
        return ts;
    }

    public void setTs(Timestamp ts) {
        this.ts = ts;
    }

    @Basic
    @Column(name = "is_fail")
    public Boolean getFail() {
        return isFail;
    }

    public void setFail(Boolean fail) {
        isFail = fail;
    }

    @Basic
    @Column(name = "flags")
    public Integer getFlags() {
        return flags;
    }

    public void setFlags(Integer flags) {
        this.flags = flags;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        PupilMeasure that = (PupilMeasure) o;
        return Objects.equals(id, that.id) &&
                Objects.equals(ts, that.ts) &&
                Objects.equals(isFail, that.isFail) &&
                Objects.equals(flags, that.flags);
    }

    @Override
    public int hashCode() {

        return Objects.hash(id, ts, isFail, flags);
    }

    @OneToMany(mappedBy = "pupilMeasure")
    public Collection<CalcValue> getCalcValues() {
        return calcValues;
    }

    public void setCalcValues(Collection<CalcValue> calcValues) {
        this.calcValues = calcValues;
    }

    @ManyToOne
    @JoinColumn(name = "examination", referencedColumnName = "id", nullable 
= false)
    public Examination getExamination() {
        return examination;
    }

    public void setExamination(Examination examination) {
        this.examination = examination;
    }
}

calc_value Entity

@Entity
@Table(name = "calc_value", schema = "public", catalog = "newmed")
public class CalcValue {
    private UUID id;
    private Double time;
    private Double value;
    private Boolean l;
    private Integer type;
    @JsonBackReference
    private PupilMeasure pupilMeasure;

    @Id
    @Column(name = "id")
    public UUID getId() {
        return id;
    }

    public void setId(UUID id) {
        this.id = id;
    }

    @Basic
    @Column(name = "time")
    public Double getTime() {
        return time;
    }

    public void setTime(Double time) {
        this.time = time;
    }

    @Basic
    @Column(name = "value")
    public Double getValue() {
        return value;
    }

    public void setValue(Double value) {
        this.value = value;
    }

    @Basic
    @Column(name = "l")
    public Boolean getL() {
        return l;
    }

    public void setL(Boolean l) {
        this.l = l;
    }

    @Basic
    @Column(name = "type")
    public Integer getType() {
        return type;
    }

    public void setType(Integer type) {
        this.type = type;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        CalcValue calcValue = (CalcValue) o;
        return Objects.equals(id, calcValue.id) &&
                Objects.equals(time, calcValue.time) &&
                Objects.equals(value, calcValue.value) &&
                Objects.equals(l, calcValue.l) &&
                Objects.equals(type, calcValue.type);
    }

    @Override
    public int hashCode() {

        return Objects.hash(id, time, value, l, type);
    }

    @ManyToOne
    @JoinColumn(name = "measure", referencedColumnName = "id", nullable = false)
    public PupilMeasure getPupilMeasure() {
        return pupilMeasure;
    }

    public void setPupilMeasure(PupilMeasure pupilMeasure) {
        this.pupilMeasure = pupilMeasure;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...