微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

CouchDB索引对此查询无效

如何解决CouchDB索引对此查询无效

  • Ubuntu 18.04
  • NodeJS 14.8.0
  • NPM 6.14.8
  • couchDB 3.1.0
  • 纳米8.2.2

我将CouchDB用作NodeJS Web应用程序的数据库。我正在使用Nano NPM软件包向CouchDB发出请求。我正在使用Nano函数db.createIndex()创建索引,db.find()查询索引。

我要传递给db.createIndex()的索引定义如下所示: {selector: { _id: {"$or": userIds} },use_index: "_design/userDoc"}

我要传递给db.find()查询看起来像这样: { index: { fields: [ '_id','last_modified','boardOwner','bio.name','ranking.rank','leveling.xp' ] },name: 'userIndex',ddoc: 'userDoc',type: 'json' }

以下是示例文档,该文档将成为

的一部分
 index: {
  "_id": "12345678","_rev": "1-f92d07661283fee7f867bd258830f666","created_at": "Tue,18 Aug 2020 14:19:09 GMT","last_modified": "Tue,"userId": 12345678,"boardOwner": true,"bio": {
    "name": "John Doe","title": "Freelance Developer","birthday": "06-08","join_date": null,"avatar": "https://stackoverflow.com","UTC_diff": -5
  },"ranking": {
    "rank": 0,"change": 0
  },"leveling": {
    "xp": 0,"level": 1,"milestones": [
      {
        "milestone": "Level 1","date": "Tue,18 Aug 2020 14:18:46 GMT"
      }
    ]
  }
}

创建索引时没有错误,并且设计文档看起来不错。设计文档中的索引看起来像索引定义。但是,当我使用db.find({selector: {_id: {"$or": userIds}},use_index: "_design/userDoc"});查询索引时,我收到一条错误消息,指出该查询没有有效的索引,它返回与我传递给db.find()的用户ID匹配的整个用户文档。 。除了认的_all_docs索引,该索引是我唯一的索引。我设置的查询错误吗?还是格式化不正确?

在Nano自述文件中,示例没有对诸如索引,名称,选择器之类的引号。在CouchDB文档中,这些内容都带有引号。我已经尝试过两种方法,但似乎没有什么作用。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。