2

首先,这个问题 - 来自 all_docs 的过滤器设计文档 - 似乎已经像这里描述的那样得到了解决:https: //plus.google.com/+JasonDeRose/posts/1iP5tu3wVqw

/mydb/_all_docs?endkey=%22_%22

并排在第一位。但是,突然在不同的设置中(实际上只是不同的部署),查询只返回一个空集合 []。似乎顺序发生了变化,没有 endkey="_" 返回完整的集合(包括设计文档)。我尝试了 endkey/startkey 的各种组合,但无法再次过滤设计文档。

最后我添加了一个过滤器并切换到 _changes?include_docs=true 来加载初始文档。我也考虑过定义一个视图,但不喜欢这会导致数据复制和更改源的一些不便(在另一个上下文中需要)。另一方面,过滤器将为每个文档执行。

endkey=%22_%22 不再起作用是一个错误吗?有没有更方便,仍然有效的方法?

4

1 回答 1

5

/_all_docs是 CouchDB 的一个特例。它使用 ASCII 排序规则,而不是普通的 Unicode 排序规则。

ASCII 顺序中的“_”字符显示在大写字母和小写字母之间。因此,如果您的文档 ID 以小写字母开头(默认行为),它们将出现任何设计文档之后。如果您的文档 ID 以大写字母开头,它们将出现在设计文档之前。

尝试创建一个 id 为:“ABC”的文档,您会看到它出现在设计文档之前,并且您过滤设计文档的技巧在这种情况下会起作用。

但是,我建议您完全停止使用 `_all_docs 视图。而是使用普通视图功能。当您创建视图时,CouchDB 会自动为您跳过设计文档。因此,如果您的视图如下所示:

function(doc){
  emit(doc._id, null);
}

您可以在没有开始或结束键的情况下查询它,并获得所有没有设计文档的文档。

另外,请查看 Unicode 排序顺序,这是您所有其他视图的顺序,在您使用 CouchDB 时理解这一点很重要。你可以在这里读到所有和它有关的:

http://docs.couchdb.org/en/stable/ddocs/views/collat​​ion.html

于 2014-05-09T16:51:36.110 回答