簡體   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