node.js – 从MongoDB中的数组中获取随机元素

这是我的数据库结构

{
     "_id" : ObjectId("576155226d1d298c2cc3edca"),"questionLibrary" : {
             "technologyName" : "CSS","questions" : [
                     {
                             "correctanswer" : {
                                     "A1" : "CSS1"
                             },"answeroption" : {
                                     "A4" : "CSS1","A3" : "CSS1","A2" : "CSS1","A1" : "CSS1"
                             },"level" : "Amature","tags" : "CSS","question" : "CSS1"
                     },{
                             "question" : "CSS2","answeroption" : {
                                     "A1" : "CSS2","A2" : "CSS2","A3" : "CSS2","A4" : "CSS2"
                             },"correctanswer" : {
                                     "A1" : "CSS2"
                             }
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS3"
                             },"answeroption" : {
                                     "A4" : "CSS3","A3" : "CSS3","A2" : "CSS3","A1" : "CSS3"
                             },"question" : "CSS3"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS4"
                             },"answeroption" : {
                                     "A4" : "CSS4","A3" : "CSS4","A2" : "CSS4","A1" : "CSS4"
                             },"question" : "CSS4"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS5"
                             },"answeroption" : {
                                     "A4" : "CSS5","A3" : "CSS5","A2" : "CSS5","A1" : "CSS5"
                             },"question" : "CSS5"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS6"
                             },"answeroption" : {
                                     "A4" : "CSS6","A3" : "CSS6","A2" : "CSS6","A1" : "CSS6"
                             },"question" : "CSS6"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS7"
                             },"answeroption" : {
                                     "A4" : "CSS7","A3" : "CSS7","A2" : "CSS7","A1" : "CSS7"
                             },"question" : "CSS7"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS8"
                             },"answeroption" : {
                                     "A4" : "CSS8","A3" : "CSS8","A2" : "CSS8","A1" : "CSS8"
                             },"question" : "CSS8"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS9"
                             },"answeroption" : {
                                     "A4" : "CSS9","A3" : "CSS9","A2" : "CSS9","A1" : "CSS9"
                             },"question" : "CSS9"
                     },{
                             "correctanswer" : {
                                     "A1" : "CSS10"
                             },"answeroption" : {
                                     "A4" : "CSS10","A3" : "CSS10","A2" : "CSS10","A1" : "CSS10"
                             },"question" : "CSS10"
                     }
             ]
     },"__v" : 3
}

从问题数组中,我想在每次触发查询时得到一个随机对象(随机问题).

我不想一次收集所有对象并在节点中进行处理.是否可以编写一个查询,以便每次都返回一个随机对象?

解决方法

试试这个逻辑

1)在数组“问题”上使用$unwind,如果使用includeArrayIndex,它将在展开文档中创建索引参见examples的文档

2)展开后,数组通过一个随机数来检索问题

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...