sql >> Databasteknik >  >> NoSQL >> MongoDB

Loop matar inte ut sant eller falskt baserat på fråga

Ett problem du har är platsen där du försöker logga resultatet av isFriend. Den loggas för närvarande precis efter att du ställt in isFriend på false när du går in i sökslingan.

Det påståendet måste flyttas strax efter den inre for-loopen.

Utan att ha alla ingångar gör det det mycket svårt att gissa var problemet kan vara.

Använda följande som indata (Kan du ange vad den faktiska inmatningen är i JSON-format?):

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);

Jag ser följande resultat:

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
  }
]

Förutom att loggsatsen är på fel plats (jag tror inte att jag ändrade semantiken för din kod), fungerar logiken med denna uppsättning ingångar. Det är troligt att den input du förväntade dig inte är vad du får.

Det visade sig att OP använde den infödda drivrutinen för mongoose för nodejs och efter att ha undersökt hittade svaret på jämförelsedelen av problemet här:Jämföra mongoose _id och strängar



  1. Hur frågar jag refererade objekt i MongoDB?

  2. pymongo:ta bort dubbletter (förminska kartan?)

  3. (nod:63208) DeprecationWarning:collection.ensureIndex är utfasad. Använd createIndex istället

  4. Hur arrayFilters-parametern fungerar i MongoDB