Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
$match Toplama işlem hattındaki aşama, belirtilen koşulla eşleşen belgeleri filtrelemek için kullanılır. bu işlemle find benzerdir, ancak sonraki aşamaya geçen belgeleri daraltmak için toplama işlem hattı içinde kullanılır. Bu aşama, sonraki aşamalarda işlenmesi gereken belge sayısını azaltarak performansı iyileştirmek için son derece kullanışlıdır.
Sözdizimi
{
$match: {
<query>
}
}
Parametreler
| Parametre | Description |
|---|---|
<query> |
Belgelerin karşılaması gereken koşulları belirten standart bir MongoDB sorgu belgesi. |
Örnekler
Stores koleksiyonundaki bu örnek belgeyi göz önünde bulundurun.
{
"_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"
]
}
Örnek 1: Dize karşılaştırması kullanarak belgeleri eşleştirme
Bu sorgu, "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5" olan _id belgeleri alır:
db.stores.aggregate([
{
$match: {
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5"
}
}
])
Bu sorgu aşağıdaki sonucu döndürür:
[
{
"_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"
}
]
Örnek 2: Sayısal karşılaştırma kullanarak belgeleri eşleştirme
Bu sorgu, toplam satışların 35.000 TL'den büyük olduğu tüm depoları alır:
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 } }
])
Bu sorgu tarafından döndürülen ilk üç sonuç şunlardır:
[
{
"_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"
}
]
Örnek 3: Alt belgeler içindeki belgeleri eşleştirme
Bu sorgu, DJ Mixer'larda 15% indirimi olan tüm depoları alır:
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 } }
])
Bu sorgu tarafından döndürülen ilk üç sonuç şunlardır:
[
{
"_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"
}
]
İlgili içerik
- MongoDB'den Azure DocumentDB'ye geçiş seçeneklerini gözden geçirin.
- MongoDB ile özellik uyumluluğu hakkında daha fazla bilgi edinin.