MongoDB Оператор Агрегационного Набора - $ anyElementTrue
MongoDB: $ anyElementTrue
Операторы MongoDB $ anyElementTrue принимают выражение с одним аргументом. то есть набор и возвращает true, если какие-либо элементы набора оцениваются как true; в противном случае возвращает false. Пустой массив возвращает false.
Синтаксис:
{$ anyElementTrue: [<выражение>]}
- Когда набор содержит вложенный элемент массива, $ anyElementTrue не опускается во вложенный массив, а оценивает массив на верхнем уровне.
- Для логического значения false, $ anyElementTrue оценивает как ложное следующее: нулевые, 0 и неопределенные значения. $ AnyElementTrue оценивает все остальные значения как true, включая ненулевые числовые значения и массивы.
Коллекция образцов survey_collection
{ "_id" : 1, "replies" : [ null ] }
{ "_id" : 2, "replies" : [ [ ] ] }
{ "_id" : 3, "replies" : [ ] }
{ "_id" : 4, "replies" : [ [ false ] ] }
{ "_id" : 5, "replies" : [ 1, true, "seven" ] }
{ "_id" : 6, "replies" : [ true, false ] }
{ "_id" : 7, "replies" : [ [ 0 ] ] }
{ "_id" : 8, "replies" : [ null ] }
{ "_id" : 9, "replies" : [ true ] }
{ "_id" : 10, "replies" : [ 0 ] }
Пример: $ anyElementTrue
Следующая операция агрегирования использует оператор $ anyElementTrue, чтобы определить, содержит ли массив ответов какое-либо значение, которое оценивается как true.
> db.survey_collection.aggregate(
... [
... { $project: { replies: 1, isAnyTrue: { $anyElementTrue: [ "$replies" ] }, _id: 0 } }
... ]
... );
После операции следующий оператор будет возвращен оператором $ anyElementTrue.
> db.survey_collection.aggregate(
... [
... { $project: { replies: 1, isAnyTrue: { $anyElementTrue: [ "$replies" ] }, _id: 0 } }
... ]
... );
{ "replies" : [ null ], "isAnyTrue" : false }
{ "replies" : [ [ ] ], "isAnyTrue" : true }
{ "replies" : [ ], "isAnyTrue" : false }
{ "replies" : [ [ false ] ], "isAnyTrue" : true }
{ "replies" : [ 1, true, "seven" ], "isAnyTrue" : true }
{ "replies" : [ true, false ], "isAnyTrue" : true }
{ "replies" : [ [ 0 ] ], "isAnyTrue" : true }
{ "replies" : [ null ], "isAnyTrue" : false }
{ "replies" : [ true ], "isAnyTrue" : true }
{ "replies" : [ 0 ], "isAnyTrue" : false }
Предыдущий: $ setIsSubset
Далее: $ allElementsTrue
Новый контент: Composer: менеджер зависимостей для PHP , R программирования
disqus2code