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.
İşleç $setField , eklenmiş belgelerde alan eklemek, güncelleştirmek veya kaldırmak için kullanılır. işleç, belge alanlarının hassas bir şekilde değiştirilmesine olanak tanır ve bu da iç içe alanları güncelleştirme, belgeleri yeniden yapılandırma ve hatta alanları tamamen kaldırma gibi görevler için yararlı olmasını sağlar.
Sözdizimi
{
$setField: {
field: <fieldName>,
input: <expression>,
value: <expression>
}
}
Parametreler
| Parametre | Description |
|---|---|
<field> |
Anahtar-değer çiftleri dizisine dönüştürülecek belge (nesne). |
<input> |
İşlenen belge veya alan. |
<value> |
Alana atanacak yeni değer. ise valuenull, alan kaldırılır. |
Örnekler
Stores koleksiyonundaki bu örnek belgeyi göz önünde bulundurun.
{
"_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
}
]
}
]
}
Örnek 1: İç içe bir alanı güncelleştirme
Bu sorgu, belirli _idbir ile eşleşen belge için yükseltme olaylarının içindeki iç içe geçmiş indirim değerlerinde koşullu güncelleştirme gerçekleştirir.
db.stores.updateOne(
{ "_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4" },
[
{
$set: {
"store.promotionEvents": {
$map: {
input: "$store.promotionEvents",
as: "event",
in: {
$setField: {
field: "discounts",
input: "$$event",
value: {
$map: {
input: "$$event.discounts",
as: "discount",
in: {
$cond: {
if: { $eq: ["$$discount.categoryName", "Laptops"] },
then: {
categoryName: "$$discount.categoryName",
discountPercentage: 18
},
else: "$$discount"
}
}
}
}
}
}
}
}
}
}
]
)
Örnek 2: Alan kaldırma
Bu sorgu alanı nesneden totalStaff kaldırırstaff.
db.collection.updateOne(
{ "store.storeId": "12345" },
[{
$set: {
"store.staff": {
$setField: {
field: "totalStaff",
input: "$store.staff",
value: null
}
}
}
}]
)
İ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.