Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Operator $dateDiff oblicza różnicę między dwiema datami w różnych jednostkach, takich jak lata, miesiące, dni itp. Warto określić czas trwania między dwoma znacznikami czasu w zestawie danych.
Składnia
$dateDiff: {
startDate: <expression>,
endDate: <expression>,
unit: <string>,
timezone: <string>, // Optional
startOfWeek: <string> // Optional
}
Parametry
| Parameter | Description |
|---|---|
startDate |
Data początkowa obliczenia. |
endDate |
Data zakończenia obliczenia. |
unit |
Jednostka czasu mierzenia różnicy. Prawidłowe wartości to: year, quartermonthweekdayhourminute, second, . millisecond |
timezone |
Opcjonalny. Strefa czasowa do użycia na potrzeby obliczeń. |
startOfWeek |
Opcjonalny. Dzień początkowy tygodnia. Prawidłowe wartości to: Sunday, , Monday, TuesdayWednesday, Thursday, , Friday. Saturday |
Przykłady
Rozważmy ten przykładowy dokument z kolekcji sklepów.
{
"_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
}
]
}
]
}
Przykład 1. Obliczanie czasu trwania w dniach między dwiema datami
To zapytanie służy $dateDiff do obliczania liczby jednostek (np. dni, miesięcy) między dwoma polami daty. Pomaga mierzyć czasy trwania, takie jak długość zdarzenia lub godzina od danej daty. To zapytanie zwraca czas trwaniaInDays wraz z innymi polami dla określonego stores dokumentu.
db.stores.aggregate([
{ $match: { _id: "e6410bb3-843d-4fa6-8c70-7472925f6d0a" } },
{ $unwind: "$promotionEvents" },
{
$project: {
eventName: "$promotionEvents.eventName",
startDate: {
$dateFromParts: {
year: "$promotionEvents.promotionalDates.startDate.Year",
month: "$promotionEvents.promotionalDates.startDate.Month",
day: "$promotionEvents.promotionalDates.startDate.Day"
}
},
endDate: {
$dateFromParts: {
year: "$promotionEvents.promotionalDates.endDate.Year",
month: "$promotionEvents.promotionalDates.endDate.Month",
day: "$promotionEvents.promotionalDates.endDate.Day"
}
},
durationInDays: {
$dateDiff: {
startDate: {
$dateFromParts: {
year: "$promotionEvents.promotionalDates.startDate.Year",
month: "$promotionEvents.promotionalDates.startDate.Month",
day: "$promotionEvents.promotionalDates.startDate.Day"
}
},
endDate: {
$dateFromParts: {
year: "$promotionEvents.promotionalDates.endDate.Year",
month: "$promotionEvents.promotionalDates.endDate.Month",
day: "$promotionEvents.promotionalDates.endDate.Day"
}
},
unit: "day"
}
}
}
}
])
To zapytanie zwraca następujący wynik.
[
{
"_id": "e6410bb3-843d-4fa6-8c70-7472925f6d0a",
"eventName": "Massive Markdown Mania",
"startDate": "2024-09-21T00:00:00.000Z",
"endDate": "2024-09-29T00:00:00.000Z",
"durationInDays": 8
}
]
Treści powiązane
- Przejrzyj opcje migracji z bazy danych MongoDB do usługi Azure DocumentDB.
- Przeczytaj więcej na temat zgodności funkcji z bazą danych MongoDB.