Заметка
Доступ к этой странице требует авторизации. Вы можете попробовать войти в систему или изменить каталог.
Доступ к этой странице требует авторизации. Вы можете попробовать сменить директорию.
Этап $match в конвейере агрегирования используется для фильтрации документов, соответствующих указанному условию. Это похоже на find операцию, но используется в конвейере агрегирования, чтобы сузить документы, проходящие до следующего этапа. Этот этап очень полезен для оптимизации производительности, уменьшая количество документов, которые необходимо обрабатывать на последующих этапах.
Синтаксис
{
$match: {
<query>
}
}
Параметры
| Параметр | Description |
|---|---|
<query> |
Стандартный документ запроса MongoDB, указывающий условия, которые должны соответствовать документам. |
Примеры
Рассмотрим этот пример документа из коллекции магазинов.
{
"_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
}
],
"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
}
]
}
],
"tag": [
"#ShopLocal",
"#SeasonalSale",
"#FreeShipping",
"#MembershipDeals"
]
}
Пример 1. Сопоставление документов с помощью сравнения строк
Этот запрос извлекает документы, _id в которых имеет значение "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5":
db.stores.aggregate([
{
$match: {
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5"
}
}
])
Этот запрос возвращает следующий результат:
[
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"name": "Lakeshore Retail | DJ Equipment Stop - Port Cecile",
"location": {
"lat": 60.1441,
"lon": -141.5012
},
"staff": {
"employeeCount": {
"fullTime": 2,
"partTime": 0
}
},
"sales": {
"salesByCategory": [
{
"categoryName": "DJ Headphones",
"totalSales": 35921
},
{
"categoryName": "DJ Cables",
"totalSales": 1000
}
],
"fullSales": 3700
},
"promotionEvents": [],
"tag": [
"#ShopLocal",
"#NewArrival",
"#NewArrival",
"#FreeShipping"
],
"company": "Lakeshore Retail",
"city": "Port Cecile",
"lastUpdated": "2025-08-04T05:57:04.619Z",
"storeOpeningDate": "2024-09-12T10:21:58.274Z"
}
]
Пример 2. Сопоставление документов с помощью числового сравнения
Этот запрос извлекает все магазины, в которых общий объем продаж превышает $35 000:
db.stores.aggregate([
{
$match: {
"sales.totalSales": { $gt: 35000 }
}
},
// Limit the result to the first 3 documents
{ $limit: 3 },
// Include only _id and name fields in the output
{ $project: { _id: 1, name: 1 } }
])
Первые три результата, возвращаемые этим запросом:
[
{
"_id": "8345de34-73ec-4a99-9cb6-a81f7b145c34",
"name": "Northwind Traders | Bed and Bath Place - West Oraland"
},
{
"_id": "57cc4095-77d9-4345-af20-f8ead9ef0197",
"name": "Wide World Importers | Bed and Bath Store - West Vitafort"
},
{
"_id": "560099f8-325f-4c35-a4e5-2e0879eb95af",
"name": "Wide World Importers | Bed and Bath Depot - North Maritzaberg"
}
]
Пример 3. Сопоставление документов в вложенных документах
Этот запрос извлекает все магазины со скидкой 15% на DJ Mixers:
db.stores.aggregate([
{
$match: {
"promotionEvents.discounts": {
$elemMatch: {
"categoryName": "DJ Mixers",
"discountPercentage": 15
}
}
}
},
// Limit the result to the first 3 documents
{ $limit: 3 },
// Include only _id and name fields in the output
{ $project: { _id: 1, name: 1 } }
])
Первые три результата, возвращаемые этим запросом:
[
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"name": "Lakeshore Retail | DJ Equipment Stop - Port Cecile"
},
{
"_id": "3c7eda41-23a1-4226-abf6-17ee9e851b5b",
"name": "Boulder Innovations | DJ Equipment Bazaar - New Ceasarview"
},
{
"_id": "63831a7d-13a9-4d8b-bf1d-ac004057f96d",
"name": "Contoso, Ltd. | DJ Equipment Shop - Reillyfurt"
}
]
Связанный контент
- Просмотрите параметры миграции из MongoDB в Azure DocumentDB.
- Дополнительные сведения о совместимости функций с MongoDB.