我正在尝试使用JPA Criteria API编写查询。我有以下课程:
Class Booking {
@ForeignKey(name = "BVisit_ID_FK")
private List<BVisit> BVisits = new LinkedList<>();
//other properties
...
}
Class Visit{
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "ID")
private Long id;
}
Class VisitSpecial extends Visit{
@Column(name = "ARRIVAL_TIME", nullable = false)
private Date arrivalTime;
@Column(name = "DEPARTURE_TIME", nullable = false)
private Date departureTime;
//other properties...
}`
如何使用JPA Criteria Api(和元模型)编写查询,该查询将查找所有具有以下内容的预订日期值(参数)介于最小到达时间与预订访问的最大出发时间之间的访问。我使用org.springframework.data.jpa.domain.Specification
查询应该看起来像这样:
SELECT Booking
from Booking B, Visit V, VisitSpecial VS
where Visit.bookingId = Booking.id and Visit.id = VisitSpecial.id
and VisitSpecial.arrivalTime = (SELECT MIN(VisitSpecial.arrivalTime) from VisitSpecial VS1 WHERE V.id = VS1.id)
and VisitSpecial.arrivalTime <= :date
and VisitSpecial.departureTime = (SELECT MAX(VisitSpecial.departureTime) from VisitSpecial VS1 Where V.id = VS1.id)
and VisitSpecial.departureTime >= :date
请参阅我的答案here,以了解通过JPA标准InheritanceType.JOINED
处理Subquery
和其他继承策略。