首页 文章

左边连接spring数据jpa和querydsl

提问于
浏览
9

我正在使用spring数据jpa和querydsl并且被困在如何编写简单的好查询到左连接两个表 . 假设我有一个Project实体和一个在Project中定义了OneToMany关系的Task实体,我想做的事情如下:

select * from project p left join task t on p.id = t.project_id where p.id = searchTerm
select * from project p left join task t on p.id = t.project_id where t.taskname = searchTerm

在JPQL中,它应该是:

select distinct p from Project p left join p.tasks t where t.projectID = searthTerm
select distinct p from Project p left join p.tasks t where t.taskName = searthTerm

我有一个ProjectRepository接口,它扩展了JpaRepository和QueryDslPredicateExecutor . 这让我可以访问方法:

Page<T> findAll(com.mysema.query.types.Predicate predicate, Pageable pageable)

我知道通过创建一个新的JPAQuery(entityManager)可以很容易地实现左连接 . 但我没有明确注入spring数据jpa的实体管理器 . 使用左连接构建谓词是否有简单明了的方法?希望有人在这里体验过这个,并且能够给我一个例子 . 谢谢 .

弗雷 .

1 回答

  • 7

    如果你想表达对任务的约束,那么你可以这样做

    QProject.project.tasks.any().id.eq(searchTerm)
    

    如果您想通过左连接来表达某些任务的预加载,则无法通过谓词来表达 . Querydsl中的谓词是一个布尔表达式,用于where,join-on和包含查询的部分 .

相关问题