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 (将#修改为@)