1

我想检索基于我使用 spring-data-couchbase 的列表集合存在的所有文档

目前我正在使用

public interface PushRepository extends CrudRepository<Push,String> 

和功能 pushRepository.findAll(phoneNumbers),但我认为它正在检索所有这些,然后进行过滤。

如何运行 N1QL 查询,以便仅检索键上的文档

 @Query("#{#n1ql.selectEntity} WHERE role = 'admin' AND #{#n1ql.filter}")
 Collection<Push> findByIds(); 

我要运行的查询如下

select * from activation use keys ["xxxxx","yyyyy"];
4

1 回答 1

1

findAll(Iterable)使用底层视图(它应该只索引与您的Push实体相对应的文档),但它确实提供了要限制的视图键,因此它应该已经非常有效了。

也就是说,如果你想做一个直接使用文档键的 N1QL 查询,那么使用@Query. 由于您直接使用键,因此不需要 WHERE 子句(您知道键对应于Push文档)。所以你可以像这样简单地做一个内联查询:

@Query("#{#n1ql.selectEntity} USE KEYS [\"xxxxx\", \"yyyyy\"]")
Collection<Push> myCustomFind();

如果您想动态构建键列表,则必须查找正确的语法,但我敢打赌,使用 SpEL 可以做到这一点。例如,从查询签名中的方法参数中获取两个键可以这样完成:

@Query("#{#n1ql.selectEntity} USE KEYS [\"#{[0]}\", \"#{[1]}\"]")
Collections<Push> findTwoByN1qlKey(String key1, String key2);
于 2016-05-26T17:14:57.537 回答