首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用自定义查询的中的Access集合字段

使用自定义查询的中的Access集合字段
EN

Stack Overflow用户
提问于 2016-12-14 00:42:00
回答 1查看 519关注 0票数 0

我正在尝试进行一个查询,以搜索我的应用程序中的所有帖子,其中包含内容或标签名称上的关键字,但只包含那些公开的帖子。我正在尝试进行JPQL搜索,但我不知道如何访问tags.name属性。

注:Post是一个具有Tag实体列表的实体;

我试过了,但它不起作用(正如我所预期的):

代码语言:javascript
运行
复制
@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)")

我已经看过文档了,但我看不出有什么办法来管理它,这里最好的方法是什么?

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-14 03:50:20

由于多个tag可以与post相关联,所以关系是从PostTag@OneToMany。在这种情况下,join应该可以工作。

尝尝这个。

代码语言:javascript
运行
复制
@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:我还没有测试这个,但是它应该能工作。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41132982

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档