Springboot Hibernate查询:按子项属性过滤

时间:2018-04-18 16:02:33

标签: sql hibernate spring-boot

您好我在SpringBoot仓库中生成@query时遇到问题。使用休眠。

我的POJO:

class Offer
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Long id;
@ManyToMany
private List<Attribute> attributes;
@ManyToMany
private List<Offer> offers;

class Attribute
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private Integer id;

它以这种方式获得“按属性提供的优惠”。但是现在我想要增强我的查询以获得“offer offer.offers.attribute”,并与之相关。

我想要的是找到所有“ Offer.attribute == 1 AND 所有Offer.offers.attribute == 2 < /强>“

使用此查询结束:

@query
"SELECT o FROM Offer o "
+ "JOIN o.attributes a "
+ "LEFT OUTER JOIN o.offers oo "
+ "LEFT OUTER JOIN o.offers.attributes ooa " <-- Problem issue
+ "WHERE o.status = 1 "
+ "AND oo.status = 1 " 
+ "AND a.id = 100 " 
+ "AND ooa.id = 101 " 
+ "GROUP BY o.id "

但是在编译时我得到了这个例外:

org.hibernate.QueryException: illegal attempt to dereference collection 
[offer0_.id.offers] with element property reference [attributes]

现在我想知道如何正确地做到这一点? 希望一些SQL / Hibernate英雄可以帮助我。

提前致谢!

格里

1 个答案:

答案 0 :(得分:1)

嗯......我更进了一步:

此查询有效:

numof_ones

但现在我至少在“Offers.offer.attributes == 101”上得到了所有结果 但我需要所有的offer.offer具有该属性。

任何提示如何继续?