如何使用带 spring-data-couchbase 的 n1ql 从文档中获取字段
How to fetch a field from document using n1ql with spring-data-couchbase
这是存储库中运行良好的查询。
public interface PlayerRepo extends CrudRepository<Player, String>{
@Query("#{#n1ql.selectEntity} WHERE code = and #{#n1ql.filter}")
public List<Player> findPlayersWithCode(String code);
}
我想从播放器文档中获取特定字段,如下所示:
@Query("#{#n1ql.selectEntity.name} WHERE code = and #{#n1ql.filter}")
public List<String> findPlayerNamesWithCode(String code);
可以这样吗,我用的是spring-data-couchbase 2.1.2
目前,这在存储库中是不可能的。 Spring Data Hopper 引入了一个允许它的 Projection
功能,但 Couchbase 存储实现尚未涵盖它。
CouchbaseTemplate
中有一些接近的东西,它有一个 findByN1QLProjection
方法,但它需要一个专用于查询的 DTO。例如:
SELECT name, lastName FROM #{#n1ql.bucket} WHERE code = AND #{#n1ql.filter}
相当于(在纯 N1QL 中):
SELECT name, lastName FROM bucketThatBacksRepository WHERE code = AND _class = "com.example.Person"
需要以下 class 才能与 findByN1QLProjection
一起工作:
public class PersonNameDTO {
private final String name;
private final String lastName;
//constructor and maybe getters/setters needed but omitted here
}
它会产生 List<PersonNameDTO>
。请注意,这与我所说的投影功能没有太大区别,除了它是围绕接口而不是具体的 DTO classes.
设计的
请注意,您不应该使用 #{#n1ql.selectEntity}
SpEL,因为它的目的是拥有一个覆盖给定实体的所有字段的大型 SELECT 子句(而在这里您想要限制SELECT 子句)。
它还涵盖了与您的存储库关联的正确存储桶的 FROM 部分,但 #{#n1ql.bucket}
还涵盖了该部分(并且仅该部分)...
这是存储库中运行良好的查询。
public interface PlayerRepo extends CrudRepository<Player, String>{
@Query("#{#n1ql.selectEntity} WHERE code = and #{#n1ql.filter}")
public List<Player> findPlayersWithCode(String code);
}
我想从播放器文档中获取特定字段,如下所示:
@Query("#{#n1ql.selectEntity.name} WHERE code = and #{#n1ql.filter}")
public List<String> findPlayerNamesWithCode(String code);
可以这样吗,我用的是spring-data-couchbase 2.1.2
目前,这在存储库中是不可能的。 Spring Data Hopper 引入了一个允许它的 Projection
功能,但 Couchbase 存储实现尚未涵盖它。
CouchbaseTemplate
中有一些接近的东西,它有一个 findByN1QLProjection
方法,但它需要一个专用于查询的 DTO。例如:
SELECT name, lastName FROM #{#n1ql.bucket} WHERE code = AND #{#n1ql.filter}
相当于(在纯 N1QL 中):
SELECT name, lastName FROM bucketThatBacksRepository WHERE code = AND _class = "com.example.Person"
需要以下 class 才能与 findByN1QLProjection
一起工作:
public class PersonNameDTO {
private final String name;
private final String lastName;
//constructor and maybe getters/setters needed but omitted here
}
它会产生 List<PersonNameDTO>
。请注意,这与我所说的投影功能没有太大区别,除了它是围绕接口而不是具体的 DTO classes.
请注意,您不应该使用 #{#n1ql.selectEntity}
SpEL,因为它的目的是拥有一个覆盖给定实体的所有字段的大型 SELECT 子句(而在这里您想要限制SELECT 子句)。
它还涵盖了与您的存储库关联的正确存储桶的 FROM 部分,但 #{#n1ql.bucket}
还涵盖了该部分(并且仅该部分)...