sql >> Databáze >  >> NoSQL >> MongoDB

Vnořený dotaz MongoDB vrací pouze poslední vyskytující se výsledek

Pro navigaci v js async jsem provedl nějaké vysílání sem a tam pomocí socket.io a fungovalo to

na straně serveru

var query = records.find({$or:[{starter:data},{receiver:data}]},{});//check the records table for all persons the logged in user has spoken to
query.sort('-createDate').exec(function (err, docs){
    if(err) throw err;

    for(var i=docs.length-1; i>= 0; i--)
    {

       var starter  = docs[i].starter;
        var receiver = docs[i].receiver;
        var lasttxt = docs[i].lastMessage; 

        if (starter == socket.usernames){
          var target = receiver;
        }else
        {
          var target = starter;
        }

      var userlast = target+" "+lasttxt;
                socket.emit('lastly', userlast);//Emit the username and last message for the client to emit back here
    }
})

Na straně klienta vyzvedněte vysílaná data

 socket.on('lastly', function(data){//Recieve the data and send right back
                  socket.emit('lastly2', data);
              });

Zpět na straně serveru vyzvedněte data odeslaná zpět

socket.on('lastly2', function(data){//receive the username and last message to work with

var check = data;
var space = check.indexOf(' ');
var name = check.substr(0, space);
var msg = check.substr(space+1);

usersrec.find({username:name},{}).lean().exec(function (errx, docx){
            if(errx) throw errx;

            docx[0].message = msg;
            socket.emit('usernames', docx);
      });

Ano, je to pravděpodobně neortodoxní, ale alespoň to odvede svou práci. Jsem otevřen lepšímu návrhu tho




  1. Jak mohu získat všechna ID dokumentů v MongoDB?

  2. Aktualizace vnořeného pole uvnitř pole mongodb

  3. Jak aktualizuji dokument Mongo po jeho vložení?

  4. Jak používat modifikátor $push update v MongoDB a C# při aktualizaci pole v dokumentu