【问题标题】:Springboot Hibernate Query: filter by childrens attributesSpring Boot Hibernate Query:按子属性过滤
【发布时间】:2018-04-18 16:02:32
【问题描述】:

您好,我在 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.offers by attribute”。但现在我想增强我的查询以获取“offer offer.offers.attribute”,并且我正在努力解决它。

我想要的是找到所有具有 "Offer.attribute == 1" AND "all 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 英雄可以帮助我。

提前致谢!

格雷戈

【问题讨论】:

    标签: sql hibernate spring-boot


    【解决方案1】:

    嗯...我更进一步:

    此查询有效:

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

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

    任何提示如何继续?

    【讨论】:

      猜你喜欢
      • 2014-10-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-08-03
      相关资源
      最近更新 更多