MongoDb Aggregation aramasında, let'in özel biçimlendirmeye ihtiyacı var mı?

Aug 18 2020

MongoDB $ aramasını Korelasyonsuz Alt Sorgularla kullanmaya çalışıyorum.
MongoDB 3.6.12'yi kullanma (destek 3.6'da başladı)https://docs.mongodb.com/manual/reference/operator/aggregation/lookup/#join-conditions-and-uncorrelated-sub-queries

Aşağıdaki işlem hattı adımı çalışıyor, ancak ilk "userB" yi ikinciyle değiştirirsem hiçbir sonuç döndürülmez.

{
from: 'friendships',
let: { requestuser: ObjectId("5c0a9c37b2365a002367df79"), postuser: ObjectId("5c0820ea17a69b00231627be") },
pipeline: [
   { 
        $match : { 
            $or : [ { "userA" : ObjectId("5c0820ea17a69b00231627be"), "userB" : ObjectId("5c0a9c37b2365a002367df79") // "userB" : '$$requestuser'
                }, 
                { 
                    "userA" : ObjectId("5c0a9c37b2365a002367df79"), 
                    "userB" : ObjectId("5c0820ea17a69b00231627be")
                }
            ], 
            "accepted" : true
        }
    },
    {
   $project: {v: 'true'}
    }
 ],
as: "match"}

Sabit kodlanmış ObjectId ile sonuçlar:

"match" : [
        {
            "_id" : ObjectId("5d6171dd319401001fd326bf"), 
            "v" : "true"
        }
    ]

Değişken kullanan sonuçlar:

"match" : [

    ]

ObjectIds'ın özel muameleye ihtiyacı varmış gibi hissediyorum. Bulabildiğim tüm örnekler, dizeler gibi basit değişkenler kullanıyor.

"$$ requestUser" öğesinin bir değer içerdiğini doğrulamak için, bunu projeksiyonda test ettim:

"match" : [
        {
            "_id" : ObjectId("5d6171dd319401001fd326bf"), 
            "v" : ObjectId("5c0a9c37b2365a002367df79")
        }
    ]

Yanıtlar

2 varman Aug 18 2020 at 11:18

Birbiriyle ilişkili olmayan alt kuyruklar kullandığınızda $expr, bir değişkeni geçmek için kullanmanız gerekir . Aşağıdaki gibi bir şey deneyebilirsiniz.

{
    $match: {
      $expr: { $or: [
            { 
                $and:[ { $eq: [ "userA", ObjectId("5c0820ea17a69b00231627be") ]
                  },
                  {
                    $eq: [ "userB", ObjectId("5c0a9c37b2365a002367df79") ] }, { $eq: [ "userB", "$$requestuser" ] } ] }, { $and:[
                  {
                    $eq: [ "userA", ObjectId("5c0a9c37b2365a002367df79") ] }, { $eq: [ "userB", ObjectId("5c0820ea17a69b00231627be") ]
                  }
                ]
            }
          
          
        ]
      },
      "accepted": true,
      
    }
  }

Nasıl göstermek için örnek bir demo oluşturduk $expriçinde çalışır lookup: İlintisiz alt sorgusu için örnek demo