gpt4 book ai didi

java - 在 Couchbase Java SDK 中使用 toBlocking() 的正确方法是什么?

转载 作者:太空宇宙 更新时间:2023-11-04 12:56:11 27 4
gpt4 key购买 nike

这里是Couchbase新手,使用Couchbase Server v4.0.0和Java SDK v2.2.3。我有以下用于运行查询的代码

Observable
.defer(new Func0<Observable<AsyncN1qlQueryResult>>() {
@Override
public Observable<AsyncN1qlQueryResult> call() {
return bucket.async().query(query);
}
})
.flatMap(new Func1<AsyncN1qlQueryResult, Observable<AsyncN1qlQueryRow>>() {
@Override
public Observable<AsyncN1qlQueryRow> call(AsyncN1qlQueryResult result) {
return result.rows();
}
})
.map(new Func1<AsyncN1qlQueryRow, JsonObject>() {
@Override
public JsonObject call(AsyncN1qlQueryRow row) {
return row.value();
}
})
.toList()
.toBlocking()
.firstOrDefault(null);

查询预计会返回两个结果,我可以保证它没有任何问题。但是,如果我让它运行,则该表达式的计算结果为 null。我怀疑我切换到阻塞可观察量的方式可能有问题,或者可能是延迟。

一个有趣的观察是,如果我在 Debug模式下运行它并在 return bucket.async().query(query); 行设置断点,并在每次使用调试器时跳过它,我总是会得到一个包含 2 个元素的列表。 (这只是查询不是罪魁祸首的另一个证据。)

有人能发现我的习语有什么问题吗?

最佳答案

虽然我不知道您的 N1QL,但请检查以下内容:

  1. 您不应该以 Observable.defer() 开头;只需从 asyncBucket.query() 开始,因为 asyncBucket.query(q)syncBucket.async().query(q) 已经以延迟方式实现。
  2. singleOrDefault()toList() 一起使用时相关。 (但是,在这种情况下可能并不重要。)

关于java - 在 Couchbase Java SDK 中使用 toBlocking() 的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35368300/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com