我是QueryDSL的新手,我关心的是创建一个带有联接的QueryDSL。我想使用一种方法并动态更改查询的联接。一个查询连接A,B表,另一个查询连接A,B,C表。我从查询参考中找不到这些。我能做这个吗?我的密码在下面。
@Override
public List<PostPreviewDto> findPostByCategoryName(String account, String categoryName, int cursor) {
return query.select(
Projections.constructor(PostPreviewDto.class,
post.id, post.title, post.time,
user.name, user.image, layout, like.count())
)
.from(post)
.innerJoin(user).on(post.user.eq(user).and(user.account.eq(account)))
.innerJoin(category).on(category.eq(post.category).and(category.name.eq(categoryName)))
.innerJoin(like).on(post.eq(like.post))
.innerJoin(mold).on(mold.eq(post.mold))
.innerJoin(layout).on(mold.eq(layout.mold).and(layout.main.eq(true)))
.where(greaterThanCursor(cursor))
.groupBy(post)
.orderBy(post.id.desc())
.limit(PAGE_SIZE)
.fetch();
}
@Override
public List<PostPreviewDto> findPostByUserId(Long userId, int cursor) {
return query.select(
Projections.constructor(PostPreviewDto.class,
post.id, post.title, post.time,
user.name, user.image, layout, like.count())
)
.from(post)
.innerJoin(user).on(post.user.eq(user).and(user.id.eq(userId)))
.innerJoin(like).on(post.eq(like.post))
.innerJoin(mold).on(mold.eq(post.mold))
.innerJoin(layout).on(mold.eq(layout.mold).and(layout.main.eq(true)))
.where(greaterThanCursor(cursor))
.groupBy(post)
.orderBy(post.id.desc())
.limit(PAGE_SIZE)
.fetch();
}发布于 2022-07-18 13:42:38
你应该能做这样的事:
private JPQLQuery<PostPreviewDto> getBaseQuery(int cursor) {
return query.select(Projections.constructor(PostPreviewDto.class,
post.id, post.title, post.time,
user.name, user.image, layout, like.count())
)
.from(post)
.innerJoin(user).on(post.user.eq(user))
.innerJoin(like).on(post.eq(like.post))
.innerJoin(mold).on(mold.eq(post.mold))
.innerJoin(layout).on(mold.eq(layout.mold).and(layout.main.eq(true)))
.where(greaterThanCursor(cursor))
.groupBy(post)
.orderBy(post.id.desc())
.limit(PAGE_SIZE);
}
@Override
public List<PostPreviewDto> findPostByCategoryName(String account, String categoryName, int cursor) {
return getBaseQuery(cursor)
.innerJoin(category).on(category.eq(post.category))
.where(user.account.eq(account).and(category.name.eq(categoryName)))
.fetch();
}
@Override
public List<PostPreviewDto> findPostByUserId(Long userId, int cursor) {
return getBaseQuery(cursor)
.where(user.id.eq(userId))
.fetch();
}https://stackoverflow.com/questions/73017612
复制相似问题