Cita:
Empezado por kalimero
yo los disparadores los aplicara a las tablas 'COMPRAS' y 'VENTAS' de forma que estos actualizarian la tabla 'STOCK'.
|
Es lo típico.
Cita:
Empezado por kalimero
Por su parte la transacción envolveria a la accion de comprar o vender y sería lo mas corta posible (como comentabas acertadamente)
|
Claro! Este es uno de los "secretos". El otro, es realizar las actualizaciones en el mismo órden. Así, la posibilidad de deadlocks, a mi criterio, se reduce bastante.
Una técnica bastante "popular", por ejemplo, en lugar de lanzar las actualizaciones contra las insersiones, es lanzarlas al "actualizar" un campo en el encabezado de movimientos de inventario, lo que te da el chance de abrir un cursor y ordenar los detalles por algún campo específico (el id_artículo, por decir algo).
Así, aún cuando la concurrencia sea alta (que tal un hipermercado con 50 o 60 cajas vendiendo cocacolas y lechugas al mismo tiempo), es poco probable que ocurra un deadlock al actualizar el stock.
Saludos.
Hasta luego.