кодесурса
«MongoDB

MongoDB Оператор Агрегационного Набора - $ anyElementTrue

script1adsense2code
script1adsense3code

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 программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
script1adsense8code
buysellads2code