MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Porównaj dwa pola tablicy w tym samym dokumencie

jeśli masz już dwa obiekty, możesz to zrobić w ten sposób. ale jeśli chcesz uzyskać go z mongoDb, powinieneś użyć $mergeObject w agregacji mongo.

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Czy kolejność kluczy ma znaczenie w dokumencie MongoDB BSON?

  2. Elementy rekurencyjne w Schema:Modelowanie Mongoose

  3. Zapytanie MongoDB według wartości, gdy klucz nadrzędny jest nieznany

  4. Jak pobrać wszystkie pasujące elementy obecne w tablicy w Mongo DB?

  5. Wskazówki dotyczące zdalnego zarządzania MongoDB