如何解决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 举报,一经查实,本站将立刻删除。