Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 03-01-2006
Avatar de kalimero
kalimero kalimero is offline
Miembro
 
Registrado: may 2003
Ubicación: Alicante
Posts: 289
Poder: 24
kalimero Va por buen camino
Hola.
Quizas (bueno, seguro jejeje) nome expique bien:
Imagina que tienes una tabla llamada 'COMPRAS' donde guardas informacion relativa al articulo y unidades compradas (entre otra). Imagina tambien que tienes otra tabla 'VENTAS' donde guardas esta vez informacion sobre unidades vendidas de un determinado articulo. Por otro la do tienes la tabla 'STOCK' donde almacenas las unidades que tienes de cada articulo en el almacen.
Pues bien, yo los disparadores los aplicara a las tablas 'COMPRAS' y 'VENTAS' de forma que estos actualizarian la tabla 'STOCK'. Por su parte la transacción envolveria a la accion de comprar o vender y sería lo mas corta posible (como comentabas acertadamente) dado que el nivel de concurrencia,según indicaba gmontes en la consulta inicial, es muy elevado.
Responder Con Cita
  #2  
Antiguo 10-01-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 30
jachguate Va por buen camino
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.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 10:18:00.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi