我正在将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是否可以?
在什么情况下应该使用第二种方法?它的代码远远多于第一个,也许它与缓存或/和速度/性能有关?这种方法的优点和缺点是什么?
答案 0 :(得分:1)
第一种方法是直接检索文档。这是最快的方法。
但是,对于数据库,您通常希望根据数据的某些功能检索文档。为此,您希望能够创建有关数据的查询。这就是第二种方法的用途。