Ескертпе
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Жүйеге кіруді немесе каталогтарды өзгертуді байқап көруге болады.
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Каталогтарды өзгертуді байқап көруге болады.
Оператор $dateFromString используется для преобразования строки даты и времени в объект даты. Эта операция может быть полезной при работе со строковыми представлениями дат, которые необходимо манипулировать или запрашивать как объекты даты.
Syntax
{
$dateFromString: {
dateString: < string > ,
format: < string > ,
timezone: < string > ,
onError: < expression > ,
onNull: < expression >
}
}
Parameters
| Parameter | Description |
|---|---|
dateString |
Строка даты и времени для преобразования в объект date. |
format |
(Необязательно) Спецификация dateStringформата даты для объекта . |
timezone |
(Необязательно) Часовой пояс, используемый для форматирования даты. |
onError |
(Необязательно) Значение, возвращаемое при синтаксическом анализе dateStringошибки. |
onNull |
(Необязательно) Значение, возвращаемое, если dateString отсутствует null или отсутствует. |
Examples
Рассмотрим этот пример документа из коллекции магазинов.
{
"_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
}
]
}
]
}
Пример 1. Преобразование дат рекламных событий в даты ISO
Этот запрос создает полные строки даты ISO из отдельных полей года, месяца и дня, используя $concat и преобразует их в начальный и конечный даты с помощью $dateFromString. Полезно, когда компоненты даты хранятся отдельно в документах.
db.stores.aggregate([
{
$match: { _id: "e6410bb3-843d-4fa6-8c70-7472925f6d0a" }
},
{
$unwind: "$promotionEvents"
},
{
$project: {
eventName: "$promotionEvents.eventName",
startDate: {
$dateFromString: {
dateString: {
$concat: [
{ $toString: "$promotionEvents.promotionalDates.startDate.Year" },
"-",
{
$cond: {
if: { $lt: ["$promotionEvents.promotionalDates.startDate.Month", 10] },
then: { $concat: ["0", { $toString: "$promotionEvents.promotionalDates.startDate.Month" }] },
else: { $toString: "$promotionEvents.promotionalDates.startDate.Month" }
}
},
"-",
{
$cond: {
if: { $lt: ["$promotionEvents.promotionalDates.startDate.Day", 10] },
then: { $concat: ["0", { $toString: "$promotionEvents.promotionalDates.startDate.Day" }] },
else: { $toString: "$promotionEvents.promotionalDates.startDate.Day" }
}
}
]
}
}
},
endDate: {
$dateFromString: {
dateString: {
$concat: [
{ $toString: "$promotionEvents.promotionalDates.endDate.Year" },
"-",
{
$cond: {
if: { $lt: ["$promotionEvents.promotionalDates.endDate.Month", 10] },
then: { $concat: ["0", { $toString: "$promotionEvents.promotionalDates.endDate.Month" }] },
else: { $toString: "$promotionEvents.promotionalDates.endDate.Month" }
}
},
"-",
{
$cond: {
if: { $lt: ["$promotionEvents.promotionalDates.endDate.Day", 10] },
then: { $concat: ["0", { $toString: "$promotionEvents.promotionalDates.endDate.Day" }] },
else: { $toString: "$promotionEvents.promotionalDates.endDate.Day" }
}
}
]
}
}
}
}
}
])
Этот запрос возвращает следующий результат.
[
{
"_id": "e6410bb3-843d-4fa6-8c70-7472925f6d0a",
"eventName": "Massive Markdown Mania",
"startDate": "2024-09-21T00:00:00.000Z",
"endDate": "2024-09-29T00:00:00.000Z"
}
]
Связанный контент
- Просмотрите параметры миграции из MongoDB в Azure DocumentDB.
- Дополнительные сведения о совместимости функций с MongoDB.