1

我想使用 QueryDslPredicateExecutor 接口创建我的 UserTask 实体的可过滤列表,因此查询字符串中给出的参数将被自动处理为谓词。

我有以下类/接口

public interface UserTaskQuerydslRepository extends CrudRepository<UserTask, String>, 
    QueryDslPredicateExecutor<UserTask>, QuerydslBinderCustomizer<QUserTask> {

    @Override
    default void customize(QuerydslBindings bindings, QUserTask userTask) {
        ...
    }
}

UserTask 是代表(couchbase)模型的我的类

@QueryEntity
@Document(expiry = 0)
public class UserTask {

    @Id
    private String id;

    ...
}

如果我用 @QueryEntity 注释这个类,那么 Maven 会为我生成 QUserTask 类

@Generated("com.mysema.query.codegen.EntitySerializer")
public class QUserTask extends EntityPathBase<UserTask> {

    private static final long serialVersionUID = 493434469L;

    public static final QUserTask userTask = new QUserTask("userTask");

    public final StringPath id = createString("id");

    ...

    public QUserTask(String variable) {
        super(UserTask.class, forVariable(variable));
    }

    public QUserTask(Path<? extends UserTask> path) {
        super(path.getType(), path.getMetadata());
    }

    public QUserTask(PathMetadata<?> metadata) {
        super(UserTask.class, metadata);
    }

}

为了生成 QUserTask,我在 pom.xml 中添加了以下几行

<plugin>
    <groupId>com.mysema.maven</groupId>
    <artifactId>apt-maven-plugin</artifactId>
    <version>1.1.3</version>
    <executions>
        <execution>
            <goals>
                <goal>process</goal>
            </goals>
            <configuration>
                <outputDirectory>target/generated-sources/apt</outputDirectory>
                <processor>com.mysema.query.apt.jpa.JPAAnnotationProcessor</processor>
                <processor>com.mysema.query.apt.QuerydslAnnotationProcessor</processor>
            </configuration>
        </execution>
    </executions>
    <dependencies>
        <dependency>
            <groupId>com.mysema.querydsl</groupId>
            <artifactId>querydsl-apt</artifactId>
            <version>3.4.3</version>
        </dependency>
    </dependencies>
</plugin>

在项目中,我们同时拥有 JPA 实体和 couchbase 实体,这就是为什么我在那里有 JPAAnnotationProcessor 的原因。

如果我像这样运行应用程序,我会收到以下错误:

org.springframework.data.mapping.PropertyReferenceException:找不到类型 UserTask 的属性 findAll!

我尝试用@NoRepositoryBean 注释我的UserTaskQuerydslRepository,它解决了我的findAll 问题,但是当我尝试将此存储库@Inject 到资源(或控制器,JHipster 将其称为资源)时,我收到以下错误

没有为依赖项找到 [.UserTaskQuerydslRepository] ​​类型的合格 bean:预计至少有 1 个 bean 有资格作为此依赖项的自动装配候选者。依赖注解:{@javax.inject.Inject()}

谁能帮助我我做错了什么?

4

2 回答 2

4

正如@mp911de 在他的评论中所说,Spring Data Couchbase 不支持QueryDsl,这解释了为什么无法创建 bean。

我可以在阅读文档时看到您的困惑来自哪里。第 5 章是所有 Spring Data store 实现共有的内容。所有商店文档都有一章具有相同的内容,通常讨论存储库基础知识。所以它可以提到不在特定实现中的东西。

您链接的部分的第一句话甚至暗示了这一点:

几个 Spring Data 模块通过 QueryDslPredicateExecutor 提供与 Querydsl 的集成。

不幸的是,有几个,但不是 Spring Data Couchbase 模块。

于 2016-07-08T07:12:26.823 回答
2

2016. 07. 11. :经过一些研究,根据@mp911de 和@simon-baslé 的回答,我们知道Spring Data Couchbase 尚不支持QueryDsl。

我找到了我想要解决的问题的解决方法(动态查询,又名。过滤列表并使其可分页)

https://github.com/TeamWanari/couchbase-query-executor

于 2016-07-11T09:43:07.110 回答