How to check if Mongo's $addToSet was a duplicate or not

前端 未结 3 2002
南方客
南方客 2021-01-13 04:15

I am using Mongoskin + NodeJS to add new keywords to MongoDB. I want to notify the user that the entry was a duplicate but not sure how to do this.

/*
* POST          


        
相关标签:
3条回答
  • 2021-01-13 04:28

    You could use db.users.findAndModify({email:"useremail@gmail.com"},[],{'$addToSet': { bodies: req.body }},{'new':false}). Pay attention to new:false switcher, it allows you to get document before update and you could check whether array contained item before update. However, it could be problematic approach if your documents are big, because you analyze it on client side.

    P.S. Your original query with $addToSet is wrong: field name is missing.

    Edit: I tried to use count returned by update, but it returns 1 for me in all cases. Here is the code I used for test with MongoDB 2.6:

    var MongoClient = require('mongodb').MongoClient;
    
    MongoClient.connect('mongodb://localhost:27017/mtest', function(err, db) {
       if(err) throw err;
    
       db.collection('test').insert({_id:1,bodies:["test"]},function(err,item){
    
         db.collection('test').update({_id:1},{$addToSet:{bodies:"test"}}, function(err,affected){
            if(err) throw err;
            console.log(affected); //1 in console
    
        });
     });
    
    });
    
    0 讨论(0)
  • 2021-01-13 04:38

    i am update a array from Collection with this JSON:

    {
        "<arrayname>":"<value>"
    }
    

    route.js

    routes.post("/api/:id", Controller.addOne);
    

    Controller.js

    async addOne(req, res) {
        //juryman id to list add
        if (Object.keys(req.body).length === 1) {
          console.log("Size 1");
        }
        await Session.findOneAndUpdate(
          { _id: req.params.id },
          { $addToSet: req.body }
        )
          .then(function(success) {
            res.send("Successfully saved.");
          })
          .catch(function(error) {
            res.status(404).send(error);
          });
      },
    

    I have five arrays in my Collection and this changes the JSON array name-value and updates correctly, the respectively Collection array. This works only for one item.

    0 讨论(0)
  • 2021-01-13 04:39

    At least in the shell you can differentiate if the document was modified or not (see nModified).

    > db.test4.update({_id:2}, {$addToSet: {tags: "xyz" }})
    WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
    
    > db.test4.update({_id:2}, {$addToSet: {tags: "xyz" }})
    WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })
    

    Update for Node

    When you use collection.update(criteria, update[[, options], callback]); you can retrieve the count of records that were modified.

    From the node docs

    callback is the callback to be run after the records are updated. Has two parameters, the first is an error object (if error occured), the second is the count of records that were modified.

    Another Update

    It seems at least in version 1.4.3 the native Mongo Node driver is not behaving as documented. It is possible to work around using the bulk API (introduced in Mongo 2.6):

    var col = db.collection('test');
    // Initialize the Ordered Batch
    var batch = col.initializeOrderedBulkOp();
    batch.find({a: 2}).upsert().updateOne({"$addToSet": {"tags": "newTag"}});
    // Execute the operations
    batch.execute(function(err, result) {
      if (err) throw err;
      console.log("nUpserted: ", result.nUpserted); 
      console.log("nInserted: ", result.nInserted); 
      console.log("nModified: ", result.nModified); // <- will tell if a value was added or not
      db.close();
    });
    
    0 讨论(0)
提交回复
热议问题