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 $range est utilisé pour générer un tableau d’entiers séquentiels. L’opérateur permet de créer des tableaux de nombres dans une plage, utiles pour la pagination, l’indexation ou les données de test.
Syntaxe
{
$range: [ <start>, <end>, <step> ]
}
Paramètres
| Paramètre | Descriptif |
|---|---|
start |
Valeur de départ de la plage (inclusive). |
end |
Valeur de fin de la plage (exclusive). |
step |
Valeur d’incrément entre chaque nombre de la plage (facultatif, valeur par défaut 1). |
Examples
Considérez cet exemple de document de la collection des magasins.
{
"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
"name": "First Up Consultants | Beverage Shop - Satterfieldmouth",
"location": {
"lat": -89.2384,
"lon": -46.4012
},
"staff": {
"totalStaff": {
"fullTime": 8,
"partTime": 20
}
},
"sales": {
"totalSales": 75670,
"salesByCategory": [
{
"categoryName": "Wine Accessories",
"totalSales": 34440
},
{
"categoryName": "Bitters",
"totalSales": 39496
},
{
"categoryName": "Rum",
"totalSales": 1734
}
]
},
"promotionEvents": [
{
"eventName": "Unbeatable Bargain Bash",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 6,
"Day": 23
},
"endDate": {
"Year": 2024,
"Month": 7,
"Day": 2
}
},
"discounts": [
{
"categoryName": "Whiskey",
"discountPercentage": 7
},
{
"categoryName": "Bitters",
"discountPercentage": 15
},
{
"categoryName": "Brandy",
"discountPercentage": 8
},
{
"categoryName": "Sports Drinks",
"discountPercentage": 22
},
{
"categoryName": "Vodka",
"discountPercentage": 19
}
]
},
{
"eventName": "Steal of a Deal Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 9,
"Day": 21
},
"endDate": {
"Year": 2024,
"Month": 9,
"Day": 29
}
},
"discounts": [
{
"categoryName": "Organic Wine",
"discountPercentage": 19
},
{
"categoryName": "White Wine",
"discountPercentage": 20
},
{
"categoryName": "Sparkling Wine",
"discountPercentage": 19
},
{
"categoryName": "Whiskey",
"discountPercentage": 17
},
{
"categoryName": "Vodka",
"discountPercentage": 23
}
]
}
]
}
Exemple 1 : Générer une plage de nombres
Cette requête illustre l’utilisation de l’opérateur pour générer un tableau d’entiers compris entre 0 et 5, où il inclut la limite gauche tout en exclut la droite.
db.stores.aggregate([{
$match: {
_id: "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6"
}
}, {
$project: {
rangeArray: {
$range: [0, 5]
}
}
}])
Cette requête retourne le résultat suivant.
[
{
"_id": "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6",
"rangeArray": [
0,
1,
2,
3,
4
]
}
]
Exemple 2 : Générer une plage de nombres avec une valeur d’étape
Cette requête illustre l’utilisation de l’opérateur pour générer un tableau de nombres pairs compris entre 0 et 18.
db.stores.aggregate([{
$match: {
_id: "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6"
}
}, {
$project: {
evenNumbers: {
$range: [0, 8, 2]
}
}
}])
Cette requête génère le résultat suivant.
[
{
"_id": "a715ab0f-4c6e-4e9d-a812-f2fab11ce0b6",
"rangeArray": [
0,
2,
4,
6
]
}
]