0

我有一个三类:医生,病人和咨询。医生和患者课程都有一个咨询列表作为字段。

@Entity
public class Consultation {
    @Id
    @GeneratedValue
    private int id;
    private Calendar scheduleDate;
    private String information;
    private String symptoms;
    @ManyToOne
    private Doctor doctor;
    @ManyToOne
    private Patient patient;
//...
}

@Entity
public class Patient {
    @Id
    @GeneratedValue
    private int id;
    private String name;
    private String ssn;
    private String address;
    @OneToMany(mappedBy = "patient")
    private List<Consultation> consultations;
//...
}

@Entity
public class Doctor  {
    @Id
    @GeneratedValue
    private int id;
    private String name;
    private String specialization;
    @OneToMany(mappedBy = "doctor")
    private List<Consultation> consultations;
//...
}

我想从单个查询中获取医生的患者;那是所有与医生进行相同咨询的患者。请注意,医生和患者之间没有任何联系。这可能吗?

select p from Patient p where p.consultations **someKeyword** (select d.consultations from Doctor d where d.id = :doctorId)

如果我没记错的话 someKeyword将是contains如果有的话

where list<entity> contains entity

如果_ _

where entity in list<entity>

但在这种情况下会有

list someKeyword list

组合将是:

select p from Patient p where p.consultations contains (select c from Consultation c where c in (select d.consultations from Doctor d where d.id = :doctorId))

但这有意义吗?

我是 JPA 和 JPQL 的初学者。

4

3 回答 3

2

就像是:

select p from Patient p
where exists (
    select c from Consultation c
    where c.patient = p
    and c.doctor.id = :doctorId
)

?

于 2012-04-21T17:58:31.887 回答
1

本教程可能会有所帮助: JPA 教程

于 2012-04-21T17:23:57.833 回答
0

您可以使用如下所示的 NamedQuery 注释

@NamedQuery(
   name = "findPatientForDoctor", 
   query = "SELECT c.patient FROM Consultation c WHERE c.doctor.id : id"))

(只检查这个查询的语法)

这将为一名患者提供医生 ID。

由于您的协会就像患者进行咨询,并且每次咨询都与患者和医生进行一对一的映射。目前,您的实体模型中没有任何关系可以为医生获取所有患者。患者与医生是多对多关系,目前您的实体似乎不支持这一点。我认为如果没有患者与医生的关系,您就无法在一次查询中获得记录。

于 2012-04-21T19:39:39.237 回答