Definição
$anyElementTrueAvalia uma array como um conjunto e retorna
truese algum dos elementos fortrue; caso contrário, retornafalse. Uma array vazia retornafalse.$anyElementTruetem a seguinte sintaxe:{ $anyElementTrue: [ <expression> ] } O próprio
<expression>deve resultar em um array, separado do array externo que indica a lista de argumentos. Para mais informações sobre expressões, consulte Expressões do .
Comportamento
Se um conjunto contiver um elemento de array aninhada, $anyElementTrue não desce para a array aninhada, mas avalia a array no nível superior.
Além do valor booleano false, $anyElementTrue avalia como false os seguintes valores: null, 0 e undefined. O $anyElementTrue avalia todos os outros valores como true, incluindo valores numéricos diferentes de zero e arrays.
Exemplo | Resultado |
|---|---|
|
|
|
|
|
|
|
|
Exemplo
Crie uma collection de exemplo chamada survey com os seguintes documentos:
db.survey.insertMany( [ { _id: 1, responses: [ true ] }, { _id: 2, responses: [ true, false ] }, { _id: 3, responses: [ ] }, { _id: 4, responses: [ 1, true, "seven" ] }, { _id: 5, responses: [ 0 ] }, { _id: 6, responses: [ [ ] ] }, { _id: 7, responses: [ [ 0 ] ] }, { _id: 8, responses: [ [ false ] ] }, { _id: 9, responses: [ null ] }, { _id: 10, responses: [ undefined ] } ] )
A seguinte operação utiliza o operador $anyElementTrue para determinar se o array responses contém algum valor igual a true:
db.survey.aggregate( [ { $project: { responses: 1, isAnyTrue: { $anyElementTrue: [ "$responses" ] }, _id: 1 } } ] )
[ { _id: 1, responses: [ true ], isAnyTrue: true }, { _id: 2, responses: [ true, false ], isAnyTrue: true }, { _id: 3, responses: [], isAnyTrue: false }, { _id: 4, responses: [ 1, true, 'seven' ], isAnyTrue: true }, { _id: 5, responses: [ 0 ], isAnyTrue: false }, { _id: 6, responses: [ [] ], isAnyTrue: true }, { _id: 7, responses: [ [ 0 ] ], isAnyTrue: true }, { _id: 8, responses: [ [ false ] ], isAnyTrue: true }, { _id: 9, responses: [ null ], isAnyTrue: false }, { _id: 10, responses: [ null ], isAnyTrue: false } ]
Nos resultados:
O documento com
_id: 1étrueporque o elemento dentro da arrayresponsesé avaliado comotrue.Documentos com
_id: 2e_id: 4sãotrueporque pelo menos um elemento dentro da arrayresponsesé avaliado comotrue.Documentos com
_id: 6,_id: 7e_id: 8sãotrueporque a arrayresponses, que é a array que$anyElementTrueavaliou para a operação, contém uma array aninhada, que$anyElementTruesempre avalia comotrue.