Couchbase View
Couchbase index: called view -- virtually another document build via map-reduce function
Map function:
Call emit() to generate a key-value pairReduce function:
Optional (disabled by reduce=false)
Used to calculate count, sum etc
Query View:
Call ViewResult.success() to check whether view execution is successful. Call ViewResult.error() to see error details
Set ViewQuery.debug(true) generate statistics information. Retrieved by ViewResult.debug()
Remember to call ViewQuery.development(true) if a development View has not been published as production view
For dev mode, full design doc name is: _design/dev_[designdoc name], to query it, just use designdoc name
If you specify designdoc name as dev_xxx, you get error:
com.couchbase.client.java.error.ViewDoesNotExistException: View does not exist
If you specify designdoc name as /dev_xxx or _design/dev_xxx, you get error:
{"error":"bad_request","reason":"p_w_uploads not supported in Couchbase"}To query composite key, do not use ViewQuery.key(String), which causes additional quote to be added to the key, add get a json format error:
invalid UTF-8 JSON {error,garbage_after_value}
Uses ViewQuery.key(JsonArray) and JsonArray.from(Object[] array). Each element of array must of correct type (String or Long)To view complete query as url parameter after encoding: use ViewQuery.toString()
Suppose a view composes of 3 field [a, b, c], it is possible to find documents by [a, b] only and [a, c] only using that view. ViewQuery.startKey([a, b, null]) and ViewQuery.startKey([a, null, c])
Sort query result: ViewQuery.desc()
References:
http://docs.couchbase.com/admin/admin/Views/views-writing.html
http://docs.couchbase.com/admin/admin/Views/views-querySample.html
Bulk operations:
Couchbase java sdk supports bulk operation, which improves performance for read/write for a number of documents
References:
http://docs.couchbase.com/developer/java-2.1/documents-bulk.html
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341