我有一个包含嵌套模式的用户模式 - 总共三层深。我没有问题添加到民意调查,但不能为我的生活添加输入。我试图让用户然后像常规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
包来更清楚地控制我的数据发生了什么。
这是我目前的代码:
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);
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 });
});;
});
答案 0 :(得分:1)
Mongoose无法跟踪像这样的子对象中的更改,因此该字段必须明确标记为需要更新,如下所示:
Cursor res = db.rawQuery("select * from "+ TABLE_NAME + " where " + COL_2 + " = ?", new String[] {"S1"});