Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
El $ operador posicional identifica un elemento de una matriz que se va a actualizar sin especificar explícitamente la posición del elemento en la matriz. El $ operador actúa como marcador de posición para el primer elemento que coincide con la condición de consulta y el campo de matriz debe aparecer como parte del documento de consulta.
Syntax
db.collection.updateOne(
{ <array>: <value> },
{ <update operator>: { "<array>.$": <value> } }
)
Parámetros
| Parámetro | Description |
|---|---|
array |
Campo de matriz que contiene el elemento que se va a actualizar. Debe formar parte de la condición de consulta. |
value |
Valor que se usa para buscar coincidencias con el elemento de matriz en la condición de consulta. |
update operator |
Operador de actualización que se va a aplicar (por ejemplo, $set, $inc, $unset). |
Examples
Considere este documento de ejemplo de la colección de tiendas.
{
"_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
}
]
}
]
}
Ejemplo 1: Proyectar el primer elemento de una matriz, que coincide con la condición
Esta consulta devuelve el primer elemento de la salesByCategory matriz, para DJ el equipo con totalSales más de 35000.
db.stores.find({
"sales.salesByCategory": {
$elemMatch: {
categoryName: {
$regex: "^DJ"
}
}
},
"sales.salesByCategory.totalSales": {
$gt: 35000
}
}, {
"sales.salesByCategory.$": 1
}).limit(2)
Los dos primeros resultados devueltos por esta consulta son:
[
{
"_id": "d3c9df51-41bd-4b4e-a26b-b038d9cf8b45",
"sales": {
"salesByCategory": [
{
"categoryName": "DJ Speakers",
"totalSales": 36972
}
]
}
},
{
"_id": "7954bd5c-9ac2-4c10-bb7a-2b79bd0963c5",
"sales": {
"salesByCategory": [
{
"categoryName": "DJ Headphones",
"totalSales": 35911
}
]
}
}
]
Ejemplo 2: Actualización del porcentaje de descuento para una categoría específica
Esta consulta actualiza el porcentaje de descuento de la categoría "Desks" en el primer evento de promoción coincidente.
db.stores.updateOne(
{
_id: "905d1939-e03a-413e-a9c4-221f74055aac",
"promotionEvents.discounts.categoryName": "Desks"
},
{
$set: { "promotionEvents.$.discounts.$[elem].discountPercentage": 25 }
},
{
arrayFilters: [{ "elem.categoryName": "Desks" }]
}
)
Ejemplo 3: Actualizar el total de la categoría de ventas
Esta consulta actualiza las ventas totales de una categoría específica mediante $ (positional operator).
db.stores.updateOne(
{
_id: "905d1939-e03a-413e-a9c4-221f74055aac",
"sales.salesByCategory.categoryName": "Desk Lamps"
},
{
$inc: { "sales.salesByCategory.$.totalSales": 1000 }
}
)