我有一个SpringBoot 2应用程序,该应用程序使用Couchbase作为数据库,使用Spring-Boot和Spring-Data以及Lombok的getters和equals方法 我已经创建了这个仓库
@ViewIndexed(designDoc = "bendicionesDoc")
public interface BenRepository extends CouchbaseRepository<BendicionesDoc, String> {
@Query("#{#n1ql.selectEntity} where #{#n1ql.filter} AND ANY uuid IN data.identifier SATISFIES uuid = $1 END")
List<BendicionesDoc<Item>> findById(Identifier identifier);
}
以及所有使用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;
}
}
但是当我运行存储库查询时,出现此错误:
java.lang.IllegalArgumentException: Unsupported type for JsonArray: class com.bendiciones.Identifier
答案 0 :(得分:0)
标识符是一个对象,您不能简单地要求Couchbase在N1QL中比较一个对象
您的方法定义应类似于:
@Query("#{#n1ql.selectEntity} where #{#n1ql.filter} AND ANY uuid IN data.identifier SATISFIES uuid.id = $1 END")
List<BendicionesDoc<Item>> findById(String id);