我正在使用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 findAll(com.mysema.query.types.Predicate predicate, Pageable pageable)
我知道通过创建一个新的JPAQuery(entityManager)可以很容易地实现左连接.但我没有明确注入spring数据jpa的实体管理器.
使用左连接构建谓词是否有简单明了的方法?
希望有人在这里体验过这个,并且能够给我一个例子.
谢谢.
弗雷.