繁体   English   中英

猫鼬不会更新子文档

[英]Mongoose won't update sub-document

我已经为此奋斗了几个小时,但似乎无法弄清楚。 我决定在一个学习项目上使用Mongo,看看自己的感觉如何。 猫鼬是推荐的使用方式,所以我也很喜欢。 我有两种模式:

var PluginSchema = new Schema({
    name: { type: String, required: true },
    slug: { type: String },
    description: { type: String },
    created_date: { type: Date, default: Date.now },
    active: { type: Boolean, default: true },
    user: { type: Schema.Types.ObjectId, ref: 'User' },
    versions: [PluginVersion.schema]
});

PluginSchema.methods.getLatestVersion = function(callback) {
    if(this.versions.length > 0) {
        this.versions.sort(function(a, b) {
            if(semver.gt(a.version, b.version)) {
                return 1;
            } else if(semver.lt(a.version, b.version)) {
                return -1;
            } else {
                return 0;
            }
        });
        callback(this.versions[this.versions.length-1]);
    } else {
        callback(undefined);
    }
};

var PluginVersionSchema = new Schema({
    version: { type: String, required: true },
    downloads: { type: Number, default: 0 },
    size: { type: Number, required: true },
    updatedChecks: { type: Number, default: 0 },
    fileName: { type: String, required: true },
    uploadedDate: { type: Date, default: Date.now }
});

这里的问题是“版本”关系。 在某些时候,我想更新插件的版本。 我要更新的是updatedChecks字段。 基本上只是updatedChecks += 1

Plugin.findById(req.params.plugin_id)
    .populate('user')
    .populate('versions')
    .exec(function(err, plugin) {
        if(err) {
            res.status(404);
            res.send("Plugin not found.");
        } else {
            plugin.getLatestVersion(function(version) {
                if(version !== undefined) {
                    pluginData = {
                        stuff: "that",
                        gets: "returned",
                        tothe: "user"
                    };

                    // This says 'Affected: 1'.  As expected
                    PluginVersion.update({_id: version._id}, {
                        updatedChecks: version.updatedChecks + 1
                    }, function(err, affected) {
                        console.log("Affected: " + affected);
                        if(err) { res.send(err); }
                        res.status(200);
                        res.json(pluginData);
                    });
                } else {
                    res.status(404);
                    res.send("No versions found for this plugin.");
                }
            });
        }
    });

到现在为止还挺好。 但是,当我尝试通过插件模式再次访问该版本时, updatedChecks值没有改变! 我检查了我正在更新的版本与从Plugin.versions字段中提取的版本中的_id值,它们是相同的。 我需要从Plugin.versions删除该版本, Plugin.versions使用更新后的值重新插入一个新版本吗? 我也尝试仅更新值并调用save()但这似乎也不起作用。

我最终通过直接从Plugin对象访问插件版本来完成这项工作。

var pluginIndex = false;
for(var i = 0; i < plugin.versions.length; i++) {
    if(plugin.versions[i]._id === version._id) {
        pluginIndex = i;
    }
}

if(pluginIndex !== false) {
    plugin.versions[pluginIndex].updatedChecks++;
    plugin.versions[pluginIndex].markModified('updatedChecks');
    plugin.versions[pluginIndex].save(function() {
        plugin.markModified('versions');
        plugin.save(function() {
            res.status(200);
            res.json(pluginData);
        });
    });
}

我还从以下方面获得了一些帮助: Mongoose save()不更新数据库文档中数组的值

这里的问题是,您的更新查询写错了。 一定是

PluginVersion.update({
    _id: version._id
}, {
    $set: {
        updatedChecks: version.updatedChecks + 1
    } 
}, function(...) {
    ...
});

要么

PluginVersion.update({
    _id: version._id
}, {
    $inc: {
        updatedChecks: 1
    } 
}, function(...) {
    ...
});

您可以在此处找到更多更新运算符: http : //docs.mongodb.org/manual/reference/operator/update/

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM