我将一个Android项目切换为使用Couchbase Lite,并且对从数据库中获取数据的方法感到困惑。
我有一个文档,其中仅包含一个属性:
Map<String, Object> properties = new HashMap<String, Object>();
properties.put("data_key", json);
Document document = database.getDocument("data_doc_id");
document.putProperties(properties);
下一步是从数据库获取存储的数据。我发现了两种方法:
第一种方法是reading the document
Document doc = database.getDocument("data_doc_id");
String json = (String) doc.getProperty("data_key");
第二个是querying
View view = database.getView("data_json");
view.setMap(new Mapper() {
@Override
public void map(Map<String, Object> document, Emitter emitter) {
if ("data_doc_id".equals(document.get("_id")) {
String json = (String) doc.getProperty("data_key");
emitter.emit("data_key", json);
}
}
}, "1.0");
QueryEnumerator queryEnumerator = view.createQuery().run();
String dataJson = "";
for (QueryRow queryRow : run) {
if ("data_key".equals(queryRow.getKey()) {
json = (String) queryRow.getValue();
}
}
可以使用第一种方法来获取存储的JSON吗?
在什么情况下应使用第二种方法?它的代码比第一个多得多,也许与缓存或/和速度/性能有关?这种方法的优缺点是什么?
最佳答案
第一种方法是直接检索文档。这是最快的方法。
但是,对于数据库,通常您希望基于数据的某些功能来检索文档。为此,您需要能够创建有关数据的查询。这就是第二种方法的目的。