如何使用带有spring-data-couchbase的n1ql从文档中获取字段

时间:2016-07-20 10:07:45

标签: n1ql spring-data-couchbase

这是存储库中的查询工作正常。

@Query("#{#n1ql.selectEntity.name} WHERE code = $1 and #{#n1ql.filter}")
public List<String> findPlayerNamesWithCode(String code);

我想从Player文档中获取特定字段,如下所示:

id dataFetcherMock = OCMClassMock([DataFetcher class]);
OCMStub([dataFetcherMock fetchSetupForCompany:[OCMArg any]
                                   completion:[OCMArg any]]).andCall(self, @selector(fetchSetupForCompany:completion:));

是否可以这样做,我使用的是spring-data-couchbase 2.1.2

1 个答案:

答案 0 :(得分:1)

目前,无法从存储库中进行此操作。 Spring Data Hopper引入了一个允许它的Projection功能,但Couchbase商店的实现还没有涵盖它。

CouchbaseTemplate中有一些东西,它有一个findByN1QLProjection方法,但它需要一个专门用于查询的DTO。例如:

SELECT name, lastName FROM #{#n1ql.bucket} WHERE code = $1 AND #{#n1ql.filter}

与(纯粹的N1QL)相同:

SELECT name, lastName FROM bucketThatBacksRepository WHERE code = $1 AND _class = "com.example.Person"

需要以下课程才能使用findByN1QLProjection

public class PersonNameDTO {
    private final String name;
    private final String lastName;

    //constructor and maybe getters/setters needed but omitted here
}

它会产生List<PersonNameDTO>。请注意,这与我所讨论的投影功能没有太大的不同,除了它是围绕接口而不是具体的DTO类设计的。

请注意,您不应该使用#{#n1ql.selectEntity} SpEL,因为它的目的是拥有一个覆盖给定实体的所有字段的大型SELECT子句(而这里您要限制SELECT子句)。

它还涵盖了与您的存储库关联的正确存储桶的FROM部分,但#{#n1ql.bucket}也涵盖了该部分(仅限该部分)......