Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
L’opérateur $isArray est utilisé pour déterminer si une valeur spécifiée est un tableau. Elle retourne true si la valeur est un tableau et false sinon. Cet opérateur est souvent utilisé dans les pipelines d’agrégation pour filtrer ou transformer des documents selon qu’un champ contient un tableau.
Syntaxe
{
$isArray: <expression>
}
Paramètres
| Paramètre | Descriptif |
|---|---|
<expression> |
Toute expression valide qui se résout en valeur que vous souhaitez vérifier. |
Examples
Considérez cet exemple de document de la collection des magasins.
{
"_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"
]
}
Exemple 1 : Vérification si un champ est un tableau
Cette requête vérifie si le sales.salesByCategory champ de chaque document de magasin est un tableau et retourne ces informations pour les trois premiers documents.
db.stores.aggregate([
{
$project: {
_id: 1,
isSalesByCategoryArray: { $isArray: "$sales.salesByCategory" }
}
},
// Limit the result to the first 3 documents
{ $limit: 3 }
])
Les trois premiers résultats retournés par cette requête sont les suivants :
[
{
"_id": "649626c9-eda1-46c0-a27f-dcee19d97f41",
"isSalesByCategoryArray": true
},
{
"_id": "8345de34-73ec-4a99-9cb6-a81f7b145c34",
"isSalesByCategoryArray": true
},
{
"_id": "57cc4095-77d9-4345-af20-f8ead9ef0197",
"isSalesByCategoryArray": true
}
]
Exemple 2 : Filtrage de documents en fonction des champs de tableau
Cette requête montre comment $isArray filtrer les documents dans lesquels le promotionEvents champ est un tableau.
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 } }
])
Les trois premiers résultats retournés par cette requête sont les suivants :
[
{
"_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"
}
]