如何使用CouchDB构建"标记"支持?

Sen*_*Liu 4 python tagging couchdb document-oriented-db

我正在使用以下视图函数来迭代数据库中的所有项目(以便查找标记),但我认为如果数据集很大,性能非常差.还有其他方法吗?

def by_tag(tag):
return  '''
        function(doc) {
            if (doc.tags.length > 0) {
                for (var tag in doc.tags) {
                    if (doc.tags[tag] == "%s") {
                        emit(doc.published, doc)
                    }
                }
            }
        };
        ''' % tag
Run Code Online (Sandbox Code Playgroud)

Bah*_*ğan 7

免责声明:我没有对此进行测试,也不知道它是否能够表现更好.

创建单个烫发视图:

function(doc) {
  for (var tag in doc.tags) {
    emit([tag, doc.published], doc)
  }
};
Run Code Online (Sandbox Code Playgroud)

并使用_view/your_view/all查询?startkey = ['your_tag_here']&endkey = ['your_tag_here',{}]

生成的JSON结构会略有不同,但您仍会获得发布日期排序.

  • 不应该是emit([doc.tags[tag], doc.published], doc)吗?否则,如果我没记错的话,你只会发出索引。 (2认同)