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 $filter est utilisé pour filtrer les éléments d’un tableau en fonction d’une condition spécifiée. Cet opérateur est utile lorsque vous devez manipuler ou récupérer des éléments de tableau spécifiques dans des documents.
Syntaxe
{
$filter: {
input: "<array>",
as: "<string>",
cond: "<expression>"
}
}
Paramètres
| Paramètre | Descriptif |
|---|---|
input |
Expression qui se résout en tableau. |
as |
Chaîne qui spécifie le nom de variable pour chaque élément du tableau d’entrée. |
cond |
Expression qui détermine s’il faut inclure l’élément dans le tableau de sortie. |
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
},
{
"categoryName": "DJ Cables",
"totalSales": 1000
}
],
"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
}
]
},
{
"eventName": "Discount Delight Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 5,
"Day": 11
},
"endDate": {
"Year": 2024,
"Month": 5,
"Day": 18
}
}
}
],
"tag": [
"#ShopLocal",
"#FashionStore",
"#SeasonalSale",
"#FreeShipping",
"#MembershipDeals"
]
}
Exemple 1 : Récupérer un élément filtré sur condition
Cette requête montre comment filtrer la catégorie de ventes en totalSalesfonction de .
db.stores.aggregate([{
$match: {
_id: "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5"
}
},
{
$project: {
filteredSalesByCategory: {
$filter: {
input: "$sales.salesByCategory",
as: "item",
cond: {
$gt: ["$$item.totalSales", 10000]
}
}
}
}
}
])
Cette requête retourne le résultat suivant.
[
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"filteredSalesByCategory": [
{
"categoryName": "DJ Headphones",
"totalSales": 35921
}
]
}
]
Contenu connexe
- Passez en revue les options de migration de MongoDB vers Azure DocumentDB.
- En savoir plus sur la compatibilité des fonctionnalités avec MongoDB.