MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

La boucle ne produit pas vrai ou faux en fonction de la requête

L'un des problèmes que vous rencontrez est l'emplacement où vous essayez d'enregistrer le résultat de isFriend. Il est actuellement enregistré juste après que vous ayez défini isFriend sur false lorsque vous entrez dans la boucle de recherche.

Cette instruction doit être déplacée juste après la boucle for interne.

Sans avoir toutes les entrées, il est très difficile de deviner où le problème pourrait être.

En utilisant ce qui suit comme entrée (pouvez-vous fournir quelle est l'entrée réelle au format JSON ?) :

var users = [
    {
        lastName: 'Smith',
        '_id': "51ee2017c2023cc816000001"
    },
    {
        lastName: 'Jones',
        '_id': "51ee2017c2023cc816000002"
    },
    {
        lastName: 'Macks',
        '_id': "51ee2017c2023cc816000003"
    }
];

var signedInUser = {
    friendRequest: [{
        "friendId": "51ee2017c2023cc816000002",
        "read": 0,
        "date_requested": "2013-07-23T06:29:39.021Z"
    }, {
        "friendId": "51ee203cc2023cc816000003",
        "read": 0,
        "date_requested": "2013-07-23T06:42:37.872Z"
    }]
};

function test(err, signedInUser) {
    console.log("\nsignedInUser.friendRequest\n" + JSON.stringify(signedInUser.friendRequest, null, 2));
    for (var x = 0; x < users.length; x++) {
        users[x].isFriend = false;
        console.log("\n" + users[x].lastName);
        for (var i = 0; i < signedInUser.friendRequest.length; i++) {
            console.log(users[x]._id + ' - ' + signedInUser.friendRequest[i].friendId);
            if (users[x]._id === signedInUser.friendRequest[i].friendId) {
                users[x].isFriend = true;
                console.log('test');
                break;
            }
        }
        console.log(users[x].isFriend);
    }

    console.log("\nFinal users:\n" + JSON.stringify(users, null, 2));
}

test(null, signedInUser);

Je vois les résultats suivants :

signedInUser.friendRequest
[
  {
    "friendId": "51ee2017c2023cc816000002",
    "read": 0,
    "date_requested": "2013-07-23T06:29:39.021Z"
  },
  {
    "friendId": "51ee203cc2023cc816000003",
    "read": 0,
    "date_requested": "2013-07-23T06:42:37.872Z"
  }
]

Smith
51ee2017c2023cc816000001 - 51ee2017c2023cc816000002
51ee2017c2023cc816000001 - 51ee203cc2023cc816000003
false

Jones
51ee2017c2023cc816000002 - 51ee2017c2023cc816000002
test
true

Macks
51ee2017c2023cc816000003 - 51ee2017c2023cc816000002
51ee2017c2023cc816000003 - 51ee203cc2023cc816000003
false

Final users:
[
  {
    "lastName": "Smith",
    "_id": "51ee2017c2023cc816000001",
    "isFriend": false
  },
  {
    "lastName": "Jones",
    "_id": "51ee2017c2023cc816000002",
    "isFriend": true
  },
  {
    "lastName": "Macks",
    "_id": "51ee2017c2023cc816000003",
    "isFriend": false
  }
]

Autre que l'instruction de journal étant au mauvais endroit (je ne pense pas avoir changé la sémantique de votre code), avec cet ensemble d'entrées, la logique fonctionne. Il est probable que l'entrée que vous attendiez n'est pas celle que vous recevez.

Il s'avère que l'OP utilisait le pilote natif de mangouste pour nodejs et, après des recherches, a trouvé la réponse à la partie de comparaison du problème ici :Comparaison de mongoose _id et de chaînes