sql >> Database >  >> NoSQL >> MongoDB

Vergelijk twee matrixvelden in hetzelfde document

als je al twee objecten hebt, kun je dit als volgt doen. maar als je het van mongoDb moet halen, moet je $mergeObject gebruiken in mongo-aggregatie.

var a = [
    {
        "_id" : "5ba8d8dfaa988532967029af",
        "level" : 2,
        "completed" : 5,
        "asset" : "5ba8caa1aa98853296702989"
    },
    {
        "_id" : "5ba8d8dfaa988532967029b0",
        "level" : 2,
        "completed" : 3,
        "asset" : "5ba8caf6aa9885329670298a"
    }];
    
 var b = [
    {
        "total" : 1,
        "asset" : "5ba8caa1aa98853296702989",
        "level" : 2
    },
    {
        "total" : 1,
        "asset" : "5ba8caf6aa9885329670298a",
        "level" : 2
    }];
    var output = [];
    function extend(obj, src) {
	src.forEach(function(key,index) { 
          if(obj[index]["asset"] == src[index]["asset"] && obj[index]["level"] == src[index]["level"]){
            let c = {...obj[index],...src[index]};
            output.push(c);
           }
         
        });
    }
  extend(a, b);
  console.log(output)


  1. MongoDB wordt afgebroken bij het uitvoeren van het mongod-commando op terminal

  2. Architectuur voor Redis-cache &Mongo voor persistentie

  3. php mongodb zoeken en sorteren in volledige tekst

  4. hoe volgnummer veilig bij te werken in mongodb