Estoy empujando subdocumentos a una matriz:
const deliverySchema = new db.Schema({ deliveryId: Number, amountDelivered: Number, price: Number }) const suppliersSchema = new db.Schema({ supplierName: String, phone: Number, deliveries: [deliverySchema] }) const delivery = { "amountDelivered": 123, "price": 123 } Suppliers.updateOne( { _id: supplierId }, { $push: { deliveries: delivery } } )
¿Cómo puedo hacer que el campo deliveryId
dentro de ese documento se incremente automáticamente en la actualización? Así que el resultado sería algo como:
{ "supplierName": "Test supplier", "phone": 12345678, "deliveries": [ { "deliveryId": 1, // Auto increment this field on update "amountDelivered": 123, "price": 123 }, { "deliverId": 2, "amountDelivered": 123, "price": 1234 } ] }
Puedes hacerlo con Aggregation Framework:
$concatArrays
: para concatenar la matriz de entregas actual con el nuevo elemento$size
: para obtener el tamaño actual de la matriz de entregas$sum
- para sumar el tamaño actual de la matriz de entregas con 1 y usar el resultado para establecer deliveryId db.collection.update({ "key": 1 }, [ { "$set": { "deliveries": { "$concatArrays": [ "$deliveries", [ { "deliveryId": { "$sum": [ 1, { "$size": "$deliveries" } ] }, "amountDelivered": 123, "price": 123 } ] ] } } } ])