更新mongodb文件,如果该文件存在,则创建

时间:2019-03-13 19:01:41

标签: node.js mongodb mongoose discord discord.js

因此,我正在尝试为我和我的朋友制作一个不和谐的bot,以跟踪CS GO 10的统计数据,并且我正在使用cheerio从提供统计数据的网站上进行爬网,然后将其传递给mongodb。抓取功能运行良好,但是我试图弄清楚如何避免为每个用户创建重复的文档。如果输入* userid 857575,它将提取该用户的统计信息,并将其放入数据库中,但是如果我多次调用,则会在数据库中生成多个文档。我的问题是,如果不一致的消息作者与数据库中的用户名匹配,我如何让mongodb更新文档?因此,如果用户名bob发送* userid3939并且bob已经存在,请更新文档。如果bob不存在,请创建文档。下面的代码,感谢任何提示。

    module.exports.run = async (bot, message, args) => {


    console.log(args);
    var userUrl = 'https://popflash.site/user/' +args;
    console.log(userUrl);
    console.log(message.member.user.tag);


     rp(userUrl)
         .then(function (html) {
             const arr = [];
             var i = 0;

             $('.stat-container', html).each(function (key, value) {
                 arr[i++] = $(this).find(".stat").text();

             });



             const stats = new Stats({
                 _id: mongoose.Types.ObjectId(),
                 userName: message.member.user.tag,
                 userId: args,
                 HLTV: arr[0],
                 ADR: arr[1],
                 HS: arr[2],
                 W: arr[3],
                 L: arr[4],
                 T: arr[5],
                 win_percent: arr[6]
             });



             stats.save()
                 .then(function (result) {                   
                    let botembed = new Discord.RichEmbed()
                        .setDescription(message.member.user + "'s 10 Man stats")
                        .setColor("#15f153")
                        .addField("stats", result)                        

                         return message.channel.send(botembed);


                 })

         })

}

module.exports.help = {
    name: "userid"
}

1 个答案:

答案 0 :(得分:0)

通过db.collection.update,您可以指定upsert: true选项来获得我认为您想要的行为。如果匹配,它将更新现有记录,否则将创建新记录。