尝试
new MockCouchbaseServer()
.createClient().async()
.query(N1qlQuery.simple("SELECT META(somebucket).id FROM diy WHERE META(somebucket).id LIKE MyKeyPrefix%;"))
.flatMap(new rx.functions.Func1[AsyncN1qlQueryResult, rx.Observable[AsyncN1qlQueryRow]] {
override def call(rows: AsyncN1qlQueryResult): rx.Observable[AsyncN1qlQueryRow] = rows.rows()
})
.map[java.util.Map[String, Object]](new rx.functions.Func1[AsyncN1qlQueryRow, java.util.Map[String, Object]] {
override def call(result: AsyncN1qlQueryRow): util.Map[String, Object] = result.value().toMap
})
.toList
.timeout(10, TimeUnit.SECONDS)
.toBlocking
.single()
这段代码与scastie的导入一起编译,如下所示
build.sbt
:
scalaVersion := "2.11.7"
libraryDependencies += "com.couchbase.client" % "java-client" % "2.5.8"
libraryDependencies += "com.couchbase.mock" % "CouchbaseMock" % "1.5.19"
或者,您可以手动定义隐式转换,这简化了代码:
implicit def convert[T, R](f: T => R): rx.functions.Func1[T, R] = (t: T) => f(t)
def main(args: Array[String]): Unit = {
new MockCouchbaseServer()
.createClient().async()
.query(N1qlQuery.simple("SELECT META(somebucket).id FROM diy WHERE META(somebucket).id LIKE MyKeyPrefix%;"))
.flatMap((rows: AsyncN1qlQueryResult) => rows.rows())
.map[java.util.Map[String, Object]]((result: AsyncN1qlQueryRow) => result.value().toMap)
.toList
.timeout(10, TimeUnit.SECONDS)
.toBlocking
.single()
}
在scala 2.12中,可以写:
new MockCouchbaseServer()
.createClient().async()
.query(N1qlQuery.simple("SELECT META(somebucket).id FROM diy WHERE META(somebucket).id LIKE MyKeyPrefix%;"))
.flatMap((rows: AsyncN1qlQueryResult) => rows.rows())
.map[java.util.Map[String, Object]](result => result.asInstanceOf[AsyncN1qlQueryRow].value().toMap)
.toList
.timeout(10, TimeUnit.SECONDS)
.toBlocking
.single()