【问题标题】:How to fetch a field from document using n1ql with spring-data-couchbase如何使用带有spring-data-couchbase的n1ql从文档中获取字段
【发布时间】:2016-07-20 10:07:45
【问题描述】:

这是存储库中运行良好的查询。

public interface PlayerRepo extends CrudRepository<Player, String>{

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

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

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

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

【问题讨论】:

  • 这个功能真的很有用,好像在 atm 上不可能,但是真的很不错。

标签: n1ql spring-data-couchbase


【解决方案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&lt;PersonNameDTO&gt;。请注意,这与我所说的投影功能没有太大区别,只是它是围绕接口而不是具体的 DTO 类设计的。

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

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

【讨论】:

  • 据我所知,使用 Couchbase 是可能的,我可以执行 select subDocumentField FROM my-bucket where meta().id = 'my-id' 之类的查询。所以只是spring data couchbase不支持它......来自更多实验用户的确认会很好:)。
  • 这在 Spring Data Ingalls 附带的版本中是可能的,couchbase 连接器将支持 spring 数据投影
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-03-21
  • 2023-03-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多