Couchbase Lite:阅读文档与查询数据

时间:2017-07-08 15:08:59

标签: android couchbase couchbase-lite couchbase-view

我正在将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);

接下来我的步骤是从数据库中获取存储的数据。我找到了两种方法:

  1. 第一种方法是reading the document

    Document doc = database.getDocument("data_doc_id");
    String json = (String) doc.getProperty("data_key");
    
  2. 第二个是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();        
        }    
    }
    
  3. 使用第一种方法获取存储的JSON是否可以?

    在什么情况下应该使用第二种方法?它的代码远远多于第一个,也许它与缓存或/和速度/性能有关?这种方法的优点和缺点是什么?

1 个答案:

答案 0 :(得分:1)

第一种方法是直接检索文档。这是最快的方法。

但是,对于数据库,您通常希望根据数据的某些功能检索文档。为此,您希望能够创建有关数据的查询。这就是第二种方法的用途。