为了账号安全,请及时绑定邮箱和手机立即绑定

请问如何使用mongoose查询内嵌数据呢

请问如何使用mongoose查询内嵌数据呢

慕的地6264312 2018-07-23 21:57:35
const userSchema = new Schema({   name:{type:String},   clubnumber:{type:String},   memo:[{     memos:{type:String}   }] })数据结构如上,现在是想匹配name和clubnumber,来查询库下的所有memodb.userModel.findOne({name:name,clubnumber:clubnumber},(e,d)=>{            console.log(d.memo);         })小弟这样写的话,控制台出来的数据是[     { memos:xxx,id:xxxx},     { memos:xxx1,id:xxxxx} ]小弟想得到的数据结构是     {memos1,memos2,memos3}//所有memos的一个数组小弟现在能想到用遍历重新创建一个数组,但是有大神知道mongoose有什么操作能直接获得这样的吗,感激不尽~
查看完整描述

2 回答

?
FishWithSmile

TA贡献1条经验 获得超0个赞

Schema里memo数组里不存对象,直接放String不就可以吗?
查看完整回答
反对 回复 2018-08-20
?
蝴蝶刀刀

TA贡献1801条经验 获得超8个赞

两种做法:

1、在创建数组模型的时候去掉_id的选项。

//定义const userChildSchema = new Schema(
    { memos: { type: String } },
    { _id: false } //子对象里去掉_id);const userSchema = new Schema({    name: { type: String },    clubnumber: { type: String },    memo: [userChildSchema]
});//查询userModel.findOne({ name: "nameeeeee" },
    { "memo": 1 },  //select
    null,    function (err, cursor) {        console.log(cursor.toJSON().memo)
    }
);

返回结果:

https://img1.sycdn.imooc.com//5b5dc7f60001f91805440222.jpg

2、mongo里可以只返回匹配的数组中的记录。

具体做法参考:mongo官网

注:
  • 以上是本机运行的结果。

  • 使用的mongoose版本为:5.2.5

  • mongo版本为:3.4


查看完整回答
反对 回复 2018-07-29
  • 2 回答
  • 0 关注
  • 1147 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信