_class свойство в CouchBase - PullRequest
       6

_class свойство в CouchBase

0 голосов
/ 15 ноября 2018

У меня есть документ, хранящийся в Couchbase.

{
  "a": {
    "b": {
      "key":"Value"
    },
 "_class":"com.nikhil.model"
  },
    "c":{
      "d":{
        "key":"value"
       },
  // _class is missing here
     },
      "_class": "com.nikhil.model"
 }

Здесь, как вы можете видеть, у меня нет _class внутри "d" в документе, из-за этого я не могу получить этодокумент.Пришло исключение отображения объекта._class используется для сопоставления вложенного объекта couchbase с моделью, необходимой для отображения, но внутри объекта "c" у меня нет этого свойства _Class, поэтому возникает исключение для отображения.Есть ли какое-то решение для этого?

Ответы [ 3 ]

0 голосов
/ 15 ноября 2018

Похоже, что вы используете Couchbase с Spring Data, самый простой способ - вернуть прогноз:

@Override
public List<UserVO> getUsers(String companyId, List<String> userIds) {

    String queryString =  "SELECT meta(t).id as id, t.login as login, t.firstName as firstName from " + getBucketName() + " t where t."+getClassFilter()+" "
            + " and t.companyId = '" + companyId + "' and t.isEnabled = true and t.isVisible = true "
            + " and meta(t).id in ["+userIds.stream().map(e->"'"+e+"'").collect( Collectors.joining( "," )) +"]";
    N1qlParams params = N1qlParams.build().consistency(ScanConsistency.NOT_BOUNDED).adhoc(true);
    ParameterizedN1qlQuery query = N1qlQuery.parameterized(queryString, JsonObject.create(), params);

    return   userRepository.getCouchbaseOperations().findByN1QLProjection(query, UserVO.class);
}
0 голосов
/ 16 января 2019

Если вы используете загрузку Spring, вам нужно переопределить метод typekey() в файле конфигурации Couchbase, который расширяет AbstractCouchbaseConfiguration и возвращает MappingCouchbaseConverter.TYPEKEY_SYNCGATEWAY_COMPATIBLE.Это заменит ваш _class строкой javaClass в документах, хранящихся на Couchbase Server.Надеюсь, это поможет.

@Configuration
public class RemoteCouchbaseConfiguration extends AbstractCouchbaseConfiguration {

    @Value("${couchbase.host}")
    private String host;

    @Value("${couchbase.bucket.bucketName}")
    private String bucketName;

    @Value("${couchbase.bucket.password}")
    private String password;

    @Override
    protected List<String> getBootstrapHosts() {
        return Arrays.asList(this.host);
    }

    @Override
    protected String getBucketName() {
        return this.bucketName;
    }

    @Override
    protected String getBucketPassword() {
        return this.password;
    }

    @Override
    public String typeKey() {
        return MappingCouchbaseConverter.TYPEKEY_SYNCGATEWAY_COMPATIBLE;
    }
}
0 голосов
/ 15 ноября 2018

Вы можете добавить _class к нему, используя инструкцию UPDATE N1QL, например:

UPDATE mybucket b
SET b.c.d._class = 'com.foo.bar'
WHERE b.c.d IS NOT MISSING
AND b.c.d._class IS MISSING

Это обновит любой документ, имеющий объект 'd' в объекте 'c', но не имеющий'_class' внутри объекта c.

...