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

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)展开后,数组通过一个随机数来检索问题

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

相关推荐