首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我可以在queryDSL中使用动态连接吗?

我可以在queryDSL中使用动态连接吗?
EN

Stack Overflow用户
提问于 2022-07-18 05:18:45
回答 1查看 193关注 0票数 0

我是QueryDSL的新手,我关心的是创建一个带有联接的QueryDSL。我想使用一种方法并动态更改查询的联接。一个查询连接A,B表,另一个查询连接A,B,C表。我从查询参考中找不到这些。我能做这个吗?我的密码在下面。

代码语言:javascript
复制
@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();
    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-07-18 13:42:38

你应该能做这样的事:

代码语言:javascript
复制
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();
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73017612

复制
相关文章

相似问题

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