我正在尝试进行一个查询,以搜索我的应用程序中的所有帖子,其中包含内容或标签名称上的关键字,但只包含那些公开的帖子。我正在尝试进行JPQL搜索,但我不知道如何访问tags.name属性。
注:Post是一个具有Tag实体列表的实体;
我试过了,但它不起作用(正如我所预期的):
@Query("SELECT p FROM Post p WHERE (p.content LIKE CONCAT('%', LOWER(:keyword),'%' OR p.tags.name LIKE CONCAT('%', LOWER(:keyword)) AND (p.open IS TRUE)")我已经看过文档了,但我看不出有什么办法来管理它,这里最好的方法是什么?
谢谢!
发布于 2016-12-14 03:50:20
由于多个tag可以与post相关联,所以关系是从Post到Tag的@OneToMany。在这种情况下,join应该可以工作。
尝尝这个。
@Query("SELECT p FROM Post p left join p.tags pTags WHERE (p.content LIKE CONCAT('%',LOWER(:keyword),'%' OR pTags.name LIKE CONCAT('%',LOWER(:keyword)) AND (p.open IS TRUE)")PS:我还没有测试这个,但是它应该能工作。
https://stackoverflow.com/questions/41132982
复制相似问题