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

Porovnejte dvě datová pole v MongoDB

Nemůžete porovnávat pole s hodnotou jiného pole s běžnou shodou dotazu. Můžete to však provést pomocí agregačního rámce:

db.so.aggregate( [
    { $match: …your normal other query… },
    { $match: { $eq: [ '$modified', '$sync' ] } }
] );

Vložil jsem tam … váš běžný další dotaz…, protože můžete tento bit použít v indexu. Takže pokud to chcete udělat pouze pro dokumenty, kde je name pole je charles můžete udělat:

db.so.ensureIndex( { name: 1 } );
db.so.aggregate( [
    { $match: { name: 'charles' } },
    { $project: { 
        modified: 1, 
        sync: 1,
        name: 1,
        eq: { $cond: [ { $gt: [ '$modified', '$sync' ] }, 1, 0 ] } 
    } },
    { $match: { eq: 1 } }
] );

Se vstupem:

{ "_id" : ObjectId("520276459bf0f0f3a6e4589c"), "modified" : 73845345, "sync" : 73234 }
{ "_id" : ObjectId("5202764f9bf0f0f3a6e4589d"), "modified" : 4, "sync" : 4 }
{ "_id" : ObjectId("5202765b9bf0f0f3a6e4589e"), "modified" : 4, "sync" : 4, "name" : "charles" }
{ "_id" : ObjectId("5202765e9bf0f0f3a6e4589f"), "modified" : 4, "sync" : 45, "name" : "charles" }
{ "_id" : ObjectId("520276949bf0f0f3a6e458a1"), "modified" : 46, "sync" : 45, "name" : "charles" }

Toto vrátí:

{
    "result" : [
        {
            "_id" : ObjectId("520276949bf0f0f3a6e458a1"),
            "modified" : 46,
            "sync" : 45,
            "name" : "charles",
            "eq" : 1
        }
    ],
    "ok" : 1
}

Pokud chcete další pole, musíte je přidat do $project .



  1. MongDB nemůže najít definici typu Promise

  2. Zná někdo funkční příklad indexu 2dsphere v pymongo?

  3. Nelze vyřešit odmítnutí slibu a odeslat pole jako odpověď

  4. Vytváření personalizovaného Newsfeedu podobného Facebooku:SQL, MongoDB?