اذهب إلى المحتوى

السؤال

نشر

لدي مجموعة من المستندات وأحاول الحصول على مجموع عناصر مصفوفة بهيئة حقل جديد بشكل مشابه للتالي:

{ 
 "department": 1, 
 "Count employees" : {$size : "$employees" }
}

ولكن يظهر لي الخطأ التالي:

The argument to $size must be an Array, but was of type: EOO

فهل يوجد طريقة لوضع القيمة 0 في حال كان العنصر فارغاً وتجاهل الخطأ السابق؟

Recommended Posts

  • 1
نشر

من MongoDB 3.2 والإصدارات الأحدث ، يمكنك استخدامه $isArray للتحقق مما إذا كان الحقل عبارة عن مصفوفة جنبًا إلى جنب مع $cond عامل التشغيل لإرجاع الحقل عند التقييم باستخدام $isArray:

{ "$project": {
    "people": 1,
    "myFieldArrayCount": { 
        "$size": { 
            "$cond": [ 
                { "$isArray": "$myFieldArray" }, 
                "$myFieldArray", 
                []
            ]
        } 
    }
}}

 

  • 1
نشر

يمكن عدم السماح للوثيقة document أن تحمل قيم فارغة null باستخدام مايشبه الشرط التالي:

$match: {
	myFieldArray: { 
		$elemMatch: { $exists: true } 
		              ^^^^^^^^^^^^^ ضمان وجود قيمة للكائن
	}
}

ولتمرير قيمة خاصية عليك استخدام معامل المرجعية '$' كالتالي:

$project:
{ 
 "department": 1,
 "employees":1,
 "Count employees" : {$size : "$employees" }
}

 

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...