Club Delphi  
    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 13-09-2005
Carlos Hurtado Carlos Hurtado is offline
Miembro
 
Registrado: dic 2004
Posts: 30
Poder: 0
Carlos Hurtado Va por buen camino
Stored Procedures, como trabajan?

Hola amigos espero que como siempre me saquen de una duda que tengo con las 'Stored Procedures'. Se trata de lo siguiente:

Supongamos que tengo una Procedure ActualizaReg que lo que hace es actualizar un registro de la Tabla Stock.

Tenemos 3 clientes conectados al servidor y los 3 deciden actualizar el mismo registro de la misma Tabla.

Fuera de la programacion normal con excepciones y errores mi consulta es:

Si la Procedure ActualizaReg esta siendo usada por el cliente 1 no podra ser usada por el resto hasta que termine su rutina?. Si no es asi, como funciona?

Gracias.
Responder Con Cita
  #2  
Antiguo 13-09-2005
Avatar de rastafarey
rastafarey rastafarey is offline
Miembro
 
Registrado: nov 2003
Posts: 927
Poder: 21
rastafarey Va por buen camino
Resp

El procedimimiento puede usarse por los cleientes que sea al mismo tiempo.

Es tan sencillo como que cada quien esta por una trasaccion diferente.
__________________
Todo se puede, que no exista la tecnología aun, es otra cosa.
Responder Con Cita
  #3  
Antiguo 13-09-2005
Avatar de nuk3zito
nuk3zito nuk3zito is offline
Miembro
 
Registrado: ago 2003
Ubicación: "Z" Land
Posts: 244
Poder: 21
nuk3zito Va por buen camino
No te confundas Carlos, Lo que se bloquea son los registros que se van actualizando (y si están dentro de alguna transacción)... no los store procedures.
__________________
Tiempo y ocasión acontecen a todos!
Responder Con Cita
  #4  
Antiguo 14-09-2005
Avatar de Crandel
[Crandel] Crandel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Parana, Argentina
Posts: 1.475
Poder: 23
Crandel Va por buen camino
La ventaja de los SP es la velocidad de ejecución dado que ya es preparados en el servidor y listos para ejecutarse.

como te dijeron lo que hay que tener en cuenta es qué registros se enstan modificando simultaneamente. Aunque es muy improbable.
__________________
[Crandel]
Responder Con Cita
  #5  
Antiguo 14-09-2005
Avatar de rastafarey
rastafarey rastafarey is offline
Miembro
 
Registrado: nov 2003
Posts: 927
Poder: 21
rastafarey Va por buen camino
Cita:
Empezado por nuk3zito
.. Lo que se bloquea son los registros que se van actualizando ...
Mira es un muy improbable que se bloquen los registros ya que nadie trabaja sobre el registro original sino sobre un version del mismo y como te dijeron anteriormente es poco probable que en un tiempo atomico ocurran dos actualizacione sexactamente al mismo tiempo. La mayoria d elos problemas suceden cuando se trata de hacer modificaciones a registrso que han sido modificacoados y no se le han notificados al resto de los clientes para que se actualicen lo cual produciria bloques muertos.

Como ib/firebird usan versionado d e regsitros por defecto los clientes modifcan un a copis dle mismo y con esto es que hay que tenr cuidado por lso registrso no s ebloquen como otros manejadores(si mas no recuerdo ib/fb es le unico que usa esto) a menos que se le desactive el versioando de registros de desactivar el versionado de registrso nunca lo he trabjado de esa forma asi que no te puedo hablar con base de que problemas se te podria presentar si lo desactivas. Aunque tampoco se si es posible desactivarlo en la version 1.5.
__________________
Todo se puede, que no exista la tecnología aun, es otra cosa.
Responder Con Cita
  #6  
Antiguo 28-12-2005
Avatar de nuk3zito
nuk3zito nuk3zito is offline
Miembro
 
Registrado: ago 2003
Ubicación: "Z" Land
Posts: 244
Poder: 21
nuk3zito Va por buen camino
Perdón... no me limité a Firebird, por lo general utilizo SQL Server, aunque hace poco hice algunos desarrollos con informix y aunque sea muy improbable que en un tiempo atómico ocurran dos actualizaciones exactamente al mismo tiempo, cuando utilizas transacciones (que supongo que como buen desarrollador las utilizas) puede suceder, o tal vez he tenido la mala fortuna que me ha sucedido varias veces. En ese caso, cuando se inicia una transacción, los registros que se vayan agregando/actualizando, son bloqueados y depende del nivel de aislamiento para definir que hacer en esos casos.
sin embargo, dado el tema de este hilo, es obvio que en los mensajes queda explicado a quien hizo la pregunta original que los store procedures no son bloqueados, solo los registros afectados por él.
__________________
Tiempo y ocasión acontecen a todos!

Última edición por nuk3zito fecha: 28-12-2005 a las 17:23:25.
Responder Con Cita
  #7  
Antiguo 29-12-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cita:
Empezado por rastafarey
La mayoria d elos problemas suceden cuando se trata de hacer modificaciones a registrso que han sido modificacoados y no se le han notificados al resto de los clientes para que se actualicen lo cual produciria bloques muertos.
negativo!
Cita:
Empezado por rastafarey
Como ib/firebird usan versionado d e regsitros por defecto los clientes modifcan un a copis dle mismo y con esto es que hay que tenr cuidado por lso registrso no s ebloquen como otros manejadores(si mas no recuerdo ib/fb es le unico que usa esto)
Amigo rastafarey, lamento informarte que estas equivocado. Interbase/Firebird efectivamente pueden mantener diferentes versiones de los registros para las transacciones de lectura, pero una vez el registro ha sido actualizado, ninguna otra transacción podrá modificarlo de nuevo.

No existe tal cosa como la "notificación al resto de los clientes para que se actualicen". Supongo que te referís a que un cliente, al leer de nuevo el registro obtenga una copia "fresca" de este. Esto está gobernado por el nivel de aislamiento de la transacción. Si tenes una transacción con nivel de aislamiento Read Commited, obtendrá la última versión confirmada cada vez que se haga un fetch del registro. Por el contrario, una transacción serializable obtendrá siempre la misma versión del registro, independientemente de cuantas veces haya sido este actualizado, una característica que la arquitectura multigeneracional de estos motores hace parecer sencilla y natural, y que tiene increibles costos de rendimiento para otros motores que te ofrezcan transacciones serializables, mientras que la mayoría simplemente no puede ofrecerlas.

Cuando un registro ha sido actualizado, se coloca un bloqueo sobre este, de manera que ninguna otra transacción podrá modificarlo hasta que el bloqueo sea liberado (mediante un commit o un rollback), y dichas modificaciones las hace el servidor y solo el servidor. No existe tal cosa como que cada cliente modificará sus propias copias...

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
  #8  
Antiguo 29-12-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cita:
Empezado por nuk3zito
aunque sea muy improbable que en un tiempo atómico ocurran dos actualizaciones exactamente al mismo tiempo, cuando utilizas transacciones (que supongo que como buen desarrollador las utilizas) puede suceder
Claro que puede ser "altamente probable", por usar la misma jerga. El que esto sea "muy improbable" o "altamente probable" depende del diseño de la aplicación y los datos que esta maneja.

Cita:
Empezado por nuk3zito
es obvio que en los mensajes queda explicado a quien hizo la pregunta original que los store procedures no son bloqueados, solo los registros afectados por él.
Esto es cierto, al menos en los motores que conozco, pero ya ves, siempre hay alguno que retuerce las cosas

Saludos

__________________
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 02:11:57.


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