Spring Data для Couchbase: использование И ЛЮБОЙ ... СООТВЕТСТВУЕТ - PullRequest
3 голосов
/ 16 октября 2019

У меня есть приложение SpringBoot 2, которое использует Couchbase в качестве базы данных, Spring-Boot и Spring-Data и Lombok для метода получения и получения. Я создал этот репозиторий

@ViewIndexed(designDoc = "bendicionesDoc")
public interface BenRepository extends CouchbaseRepository<BendicionesDoc, String> {

    @Query("#{#n1ql.selectEntity} where #{#n1ql.filter} AND ANY uuid IN data.identifier.id SATISFIES uuid = $1 END")
    List<BendicionesDoc<Item>> findById(String id);


}

и здесь всеобъекты, созданные с помощью библиотеки Lombok

public class BendicionesDoc<T>implements Serializable {


        @Field
        private T data;

    }

и

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@JsonInclude(NON_NULL)
public class Item {

    private List<Identifier> identifier;


}

и

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@JsonInclude(NON_NULL)
@EqualsAndHashCode
public class Identifier {

    private String id;
    private MasterServant idContext;
    private MasterServant idScope;

}

и

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@JsonInclude(NON_NULL)
@EqualsAndHashCode(onlyExplicitlyIncluded = true)
public class MasterServant {

    private String context;
    @JsonValue
    @EqualsAndHashCode.Include
    private String value;

    private Name valueDescription;

    @JsonCreator
    public MasterServant(String value) {
        this.value = value;
    }

}

Но при запуске репозиториязапрос я всегда получал 0 результатов, даже есть документы. в БД:

1 Ответ

0 голосов
/ 23 октября 2019

Вам нужно определить reference type в CouchbaseRepository<T, K>, затем просто добавить тип ссылки Item как CouchbaseRepository<BendicionesDoc<Item>, String> и просто использовать ключевые слова запроса репозитория для findById(String id).

public interface BenRepository extends CouchbaseRepository<BendicionesDoc<Item>, String> { 

    List<BendicionesDoc<Item>> findById(String id);

}
...