执行findAll()时Spring引导和couchbase中的InvalidDataAccessResourceUsageException

问题描述 投票:1回答:2

我想从Couchbase存储桶中获取某种类型的所有文档。

我创建了一个扩展CatRepositoryCouchbaseRepository,所以我继承了findAll()方法。

运行程序并到达以下行时:

Iterable<Cat> all = catRepository.findAll();

我收到以下错误:

Servlet.service() for servlet [dispatcherServlet] in context with path [] 
threw exception [Request processing failed; nested exception is 
org.springframework.dao.InvalidDataAccessResourceUsageException: View  cat/all does not exist.; nested exception is 
com.couchbase.client.java.error.ViewDoesNotExistException: View cat/all does not exist.] with root cause

rx.exceptions.OnErrorThrowable$OnNextValue: OnError while emitting onNext 
value: com.couchbase.client.java.document.json.JsonObject.class
at rx.exceptions.OnErrorThrowable.addValueAsLastCause(OnErrorThrowable.java:118) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OnSubscribeMap$MapSubscriber.onNext(OnSubscribeMap.java:73) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OnSubscribeMap$MapSubscriber.onNext(OnSubscribeMap.java:77) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.producers.SingleProducer.request(SingleProducer.java:65) ~[rxjava-1.2.7.jar:1.2.7]
at rx.Subscriber.setProducer(Subscriber.java:211) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OnSubscribeMap$MapSubscriber.setProducer(OnSubscribeMap.java:102) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OnSubscribeMap$MapSubscriber.setProducer(OnSubscribeMap.java:102) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OperatorSingle$ParentSubscriber.onCompleted(OperatorSingle.java:113) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OperatorObserveOn$ObserveOnSubscriber.checkTerminated(OperatorObserveOn.java:281) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.operators.OperatorObserveOn$ObserveOnSubscriber.call(OperatorObserveOn.java:216) ~[rxjava-1.2.7.jar:1.2.7]
at rx.internal.schedulers.ScheduledAction.run(ScheduledAction.java:55) ~[rxjava-1.2.7.jar:1.2.7]
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) ~[na:1.8.0_161]
at java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:266) ~[na:1.8.0_161]
at java.util.concurrent.FutureTask.run(FutureTask.java) ~[na:1.8.0_161]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) ~[na:1.8.0_161]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) ~[na:1.8.0_161]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) ~[na:1.8.0_161]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) ~[na:1.8.0_161]
at java.lang.Thread.run(Thread.java:748) [na:1.8.0_161]

这是存储库(无)代码:

public interface CatsRepository extends CouchbaseRepository<Cat, String> {
  // nothing here, as the findAll() is inherited
}
java spring-data couchbase
2个回答
0
投票

findAll需要在Couchbase上创建视图。

您可以通过Couchbase UI执行此操作:

  • 登录Couchbase UI
  • 转到索引(左手菜单)
  • 意见(中上部)
  • 选择你的水桶(右上方下拉)
  • 添加视图(右上角)
  • 使用与您的对象匹配的名称(foo)和视图名称all,因此该文档称为_design/[bucket_name]/foo并查看all
  • (可选)编辑视图,替换地图代码:
    function (doc, meta) {
        if (doc._class == "[your_package].Foo") {
            emit(meta.id, null);
        }
    }
  • 发布视图(然后应显示在“生产视图”列表中)

注意:这个答案与Couchbase 6有关。对于旧版本/新版本,该过程可能会有所不同


0
投票

您还可以使用注释@ViewIndexed,如下所示:

@N1qlPrimaryIndexed
@ViewIndexed(designDoc = "area")
public interface AreaRepository extends CouchbaseRepository<Area, String> {

     List<Area> findByBusinessUnityIdAndRemoved(String businessId, boolean removed);
}
© www.soinside.com 2019 - 2024. All rights reserved.