$floor
The `$floor` operator returns the largest integer less than or equal to the specified number.
Syntax
{ $floor: <number> }
Parameters
<number>
stringrequiredAny valid expression that resolves to a number.
Examples
Sample Data
{
"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
"sales": {
"totalSales": 75670,
"salesByCategory": [
{ "categoryName": "Wine Accessories", "totalSales": 34440 }
]
}
}
Calculate the floor of total sales and discounts
Calculate the floor of the average sales volume for a given store and the floor of sales per category.
Query:
db.stores.aggregate([
{ $match: { _id: "40d6f4d7-50cd-4929-9a07-0a7a133c2e74" } },
{
$project: {
name: 1,
averageSalesFloor: {
$floor: {
$divide: ["$sales.totalSales", { $size: "$sales.salesByCategory" }]
}
},
categoriesWithFloorSales: {
$map: {
input: "$sales.salesByCategory",
as: "category",
in: {
categoryName: "$$category.categoryName",
floorSales: { $floor: "$$category.totalSales" }
}
}
}
}
}
])
Output:
[
{
"_id": "40d6f4d7-50cd-4929-9a07-0a7a133c2e74",
"name": "Proseware, Inc. | Home Entertainment Hub",
"averageSalesFloor": 30372,
"categoriesWithFloorSales": [
{ "categoryName": "Sound Bars", "floorSales": 2120 }
]
}
]