Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
El $isArray operador se usa para determinar si un valor especificado es una matriz. Devuelve true si el valor es una matriz y false , de lo contrario, . Este operador se usa a menudo en canalizaciones de agregación para filtrar o transformar documentos en función de si un campo contiene una matriz.
Syntax
{
$isArray: <expression>
}
Parámetros
| Parámetro | Description |
|---|---|
<expression> |
Cualquier expresión válida que se resuelva en un valor que desee comprobar. |
Examples
Considere este documento de ejemplo de la colección de tiendas.
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"name": "Lakeshore Retail | DJ Equipment Stop - Port Cecile",
"location": {
"lat": 60.1441,
"lon": -141.5012
},
"staff": {
"totalStaff": {
"fullTime": 2,
"partTime": 0
}
},
"sales": {
"salesByCategory": [
{
"categoryName": "DJ Headphones",
"totalSales": 35921
}
],
"fullSales": 3700
},
"promotionEvents": [
{
"eventName": "Bargain Blitz Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 3,
"Day": 11
},
"endDate": {
"Year": 2024,
"Month": 2,
"Day": 18
}
},
"discounts": [
{
"categoryName": "DJ Turntables",
"discountPercentage": 18
},
{
"categoryName": "DJ Mixers",
"discountPercentage": 15
}
]
}
],
"tag": [
"#ShopLocal",
"#SeasonalSale",
"#FreeShipping",
"#MembershipDeals"
]
}
Ejemplo 1: Comprobación de si un campo es una matriz
Esta consulta comprueba si el sales.salesByCategory campo de cada documento de almacén es una matriz y devuelve esa información para los tres primeros documentos.
db.stores.aggregate([
{
$project: {
_id: 1,
isSalesByCategoryArray: { $isArray: "$sales.salesByCategory" }
}
},
// Limit the result to the first 3 documents
{ $limit: 3 }
])
Los tres primeros resultados devueltos por esta consulta son:
[
{
"_id": "649626c9-eda1-46c0-a27f-dcee19d97f41",
"isSalesByCategoryArray": true
},
{
"_id": "8345de34-73ec-4a99-9cb6-a81f7b145c34",
"isSalesByCategoryArray": true
},
{
"_id": "57cc4095-77d9-4345-af20-f8ead9ef0197",
"isSalesByCategoryArray": true
}
]
Ejemplo 2: Filtrado de documentos basados en campos de matriz
Esta consulta muestra el uso de $isArray para filtrar documentos en los que el promotionEvents campo es una matriz.
db.stores.aggregate([
{
$match: {
$expr: { $isArray: "$promotionEvents" }
}
},
// Limit the result to the first 3 documents
{ $limit: 3 },
// Include only _id and name fields in the output
{ $project: { _id: 1, name: 1 } }
])
Los tres primeros resultados devueltos por esta consulta son:
[
{
"_id": "649626c9-eda1-46c0-a27f-dcee19d97f41",
"name": "VanArsdel, Ltd. | Musical Instrument Outlet - East Cassie"
},
{
"_id": "8345de34-73ec-4a99-9cb6-a81f7b145c34",
"name": "Northwind Traders | Bed and Bath Place - West Oraland"
},
{
"_id": "57cc4095-77d9-4345-af20-f8ead9ef0197",
"name": "Wide World Importers | Bed and Bath Store - West Vitafort"
}
]