使用嵌套模式在Mongoose中创建subsubdocs

时间:2017-10-18 21:41:45

标签: node.js mongodb mongoose mongoose-schema

我有一个包含嵌套模式的用户模式 ​​- 总共三层深。我没有问题添加到民意调查,但不能为我的生活添加输入。我试图让用户然后像常规json一样处理数据(例如获取polls数组的索引,然后推送到嵌套的输入数组)。我尝试创建一个新输入并将其推送到输入数组。

以下代码适用于为给定用户创建新的轮询:

const poll = user.polls.create({});
user.polls.push(poll);
user.save(function(err, data) {
   //more stuff here
})

但是,当我在民意调查中尝试相同的方法时,我无法保存到数据库。

const poll = user.polls.id(<some _id>);
const input = poll.create({}); // or user.polls.id(<some _id>).create({});
poll.inputs.push(input);

根据我目前的数据结构,我已经来回尝试了几件事似乎无法实现这一点。我已经在SO以及其他在线资源上阅读了几篇文章,但大多数都提供了第一个嵌入式子文件的示例,而不是subdoc的子文件。您将提供的任何帮助将不胜感激。谢谢。我正在考虑在这个项目中删除Mongoose,只是使用mongodb包来更清楚地控制我的数据发生了什么。

这是我目前的代码:

来自User.js

const InputSchema = new Schema({
    [ALL SORTS OF VARIOUS DATA HERE] 
});

const PollSchema = new Schema({
    inputs: [InputSchema],
});

const UserSchema = new Schema({
    polls: [PollSchema]
});

module.exports = mongoose.model('User', UserSchema);

来自controllers.js

const User = require('../models/User');

router.post('/polls/inputs/add/:creatorId', function(req, res) {
    let title = req.body.option.title,
        order = req.body.option.order,
        voters= [];

    User.findOne({ creatorId: req.params.creatorId })
        .then(user => {

            const input = {order, title, voters};

            user.polls.id(req.body.pollId).inputs.push(input);

            user.save(function(err, data) {
                if (err) {
                    res.statusCode = 500;
                    return res.json({ title: 'Save Error', message: err });
                }
                console.log('Success!');
                res.json({ input: input });
            });
        }).catch(err => {
            res.statusCode = 500;
            return res.json({ title: 'DB Error', message: err });
        });;
});

1 个答案:

答案 0 :(得分:1)

Mongoose无法跟踪像这样的子对象中的更改,因此该字段必须明确标记为需要更新,如下所示:

Cursor res = db.rawQuery("select * from "+ TABLE_NAME + " where " + COL_2 + " = ?", new String[] {"S1"});