FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Como darle un Tiempo de Vida a un Bloqueo ????
Uso Firebird 1.53, D6, IBX 6.08
Tengo una Tabla de Consecutivos con la siguiente estructura: Tabla_Consecutivos Serie Folio FM 1 FH 2 Tengo una Aplicación de Facturación, donde hace poco me paso un problema, mandaron una factura a grabar y antes de guardar bloqueo el folio de la factura, con el objetivo de que al bloquear dicho folio las demás computadoras se tienen que esperar hasta que se liberé, pero desgraciadamente cuando estaba bloqueado dicho Folio win98 marco el famoso error con fondo AZUL que decía algo de "VXD.... etc. etc." por lo que se bloqueo la computadora y por lo tanto las demás se quedaron bloqueadas esperando a ser liberado el folio, aqui no hubo de otra más que apagar las computadoras y reiniciar el Firebird Server del Servidor. Mi pregunta es, habra algún parámetro ó configuración donde se le indique a Firebird que los bloqueos durarán X Segundos ó Minutos ???? con el objetivo de que no haya necesidad de Reiniciar el Firebird Server. Agradezco cualquier sugerencia.... |
#2
|
||||
|
||||
Usa un generador para cada serie y asunto resuelto... solo mandas a generar el folio con el clasico GEN_ID(FM,1) y creas tantos generadores como series necesites... con estos ya no es necesario hacer bloqueos explicitos... de hecho creo que no es una buena práctica que uses una tabla para esto..
Es solo mi apreciación un experto ya te dirá como hacerlo
__________________
"Hey, nena, debe ser genial ser tú y verme a mí mismo..." |
#3
|
||||
|
||||
????
Yo uso esa tabla para tomar los FOLIOS REALES DE LAS FACTURAS no los folios internos, es por eso que no puedo usar los generadores, no se si has visto las formas de las facturas que ya vienen impresas con su FOLIO, esa es la razón principal de no usar generadores....
Gracias por tu sugerencia. |
#4
|
|||
|
|||
Esa es la principal razon por la que se desaconseja el uso de bloqueos pesimistas.
Si se usan bloqueos pesimistas hay que apechugar con los problemas que pueden provocar Yo intentaria rehacer el sistema sin utilizar bloqueos pesimistas. Saludos |
#5
|
||||
|
||||
????
Cita:
No sería mejor que me aconsejarás como puedo evitar que cuando se guarda una Factura otro usuario no tome el mismo folio ???? De los 2 años que tengo usando bloqueos pesimistas esta es la primer vez en que me he visto con problemas, espero no hayan otros más con motivo de los bloqueos pesimistas. |
#6
|
||||
|
||||
Hay una Esperanza
Encontre algo en el archivo Firebird.conf, hay un parámetro que se llama DeadLockTimeOut donde se le añade el tiempo en segundos de un bloqueo muerto, puediera ayudarme, voy a realizar pruebas.
|
#7
|
|||
|
|||
Una duda?
Dices que tu factura ya vienen con el folio de echo aqui se manejan igual, pero para que una tabla para guardar los folios, yo lo que hago es usar un id auntoinc para el identificador, un id_folio para las notas foliadas y seriarlas segun se ocupen en cada caja y un campo referencia en el cual se almacena el folio de factura en caso de que se emita una por esa venta, como no se que folio pudiera llegar a ocupar en determinado momento pues simplemente a la hora de facturar el usuario escribira el folio de la factura y lo guarda de esta forma no tengo que bloquear nada, bueno no soy un experto es esto de la facturacion y tal ves este mal pero asi es como vi que funcionaria mejor y no creo que al usuario le de un ataque por escribir unos numeros.
Saludos. |
#8
|
|||
|
|||
Yo estoy trabajando en un sistema de inventarios, donde los números consecutivos los genera la aplicación, basándome en una tabla de control. Cuando más de un cliente trata de guardar un registro nuevo, primero verifico si el número que voy a usar no está ya usado, si es así, obtengo un número nuevo y lo uso. Todo esto con un Trigger Before Insert de la tabla.
Ahora, desde la aplicación, al momento de guardar el registro lo hago mediante un repeat..until de esta forma:
El código no es exactamente el mismo, pero con esto resolví el problema de los DeadLock... Espero te sirva... Saludos... |
#9
|
||||
|
||||
Cita:
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
#10
|
|||
|
|||
Bueno, si hay un TransactionStart y un Commit o Rollback en caso de otro tipo de error, pero como este código es para guardar uno o más registros en sucesión, estos van afuera del código que puse...
Saludos... |
#11
|
||||
|
||||
No entendí esto
Cita:
Que componentes usas????
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
#12
|
|||
|
|||
Lo que sucede es que en realidad tengo creado un tipo de framework para trabajar con objetos en lugar de registros...
Entonces, en lugar de hacer DataSet.Post, en realidad hago algo como Objeto.Store, entonces, internamente el método mencionado hace el manejo de las transacciones... Ahora, cuando quiero manejar inserciones masivas, vamos a decirle así, por ejemplo tipo master-detail, lo que hago es iniciar una transacción, realizar el ciclo de inserciones (Objeto.Store) y al final el Commit o Rollback dependiendo de si todo estuvo bien u ocurrió un error. Mi código es más o menos ásí:
Espero que con esto te aclare mejor las cosas... Saludos... |
#13
|
|||
|
|||
Guardar lo que pides hasta que lo necesites
bueno no se si te servira, yo uso generadores, pero el cliente pide un numero, y lo guardo en el registro de windows, hasta que lo necesito, una simple variable de cod_factura en el regitro, si esta variable es vacia pido un nuevo numero al generador, si esta llena uso ese valos, si hay error no vacio la variable y si no lo hay la vacio y asi garantizo que aunque se corte la luz como esta en el registro de windows puedo rescatar el número que pedí.
Espero que te sirva
__________________
Saludos desde Sucre - Bolivia "Si te lo puedes imaginar lo puedes resolver" Pyriel |
#14
|
||||
|
||||
Vuelvo a reabrir este hilo que hace más de 2 años lo abri, sigo con este problema de los bloqueos pesimistas, no me funciona el parametro DeadlockTimeout dentro de firebird.conf, no mata los bloqueos que duran el tiempo que especifico, lo que ha de esperar firebird es que ocurra un problema en el bloqueo pero no especifica que problemas considera para activar el DeadlockTimeout, espero a alguien haya encontrado algo para RE-matar un bloqueo muerto ....
Código:
DeadlockTimeout = Número de segundos (entero) que el gestor de bloqueos esperará despues de la aparición de un conflicto antes de purgar todos los bloqueos de procesos muertos y realizar un ciclo posterior de detección de deadlocks. Normalmente el motor detecta instantáneamente los deadlocks. El timeout de deadlocks solo se dispara cuando algo va mal.El valor por defecto de 10 segundos es adecuado para la mayoría de las situaciones. Configurar un valor menos no aumenta necesariamente la velocidad a la que los deadlocks problemáticos devuelven una excepción de conflicto. Si es demasiado bajo, el efecto puede ser escaneos extra innecesarios que degraden el rendimiento del sistema.
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King Última edición por AGAG4 fecha: 16-10-2008 a las 17:58:43. Razón: Corrección |
#15
|
||||
|
||||
Idea
Saludos.
No se si migraste o podrías migrar a FB >= 2. En esta versión existe la clausula LOCK TIMEOUT. Cita:
Cita:
Cita:
Hasta luego.
__________________
Gracias, Rolphy Reyes |
#16
|
||||
|
||||
Te agradezco la sugerencia, ya lo habia pensado, en este momento estoy en la version 1.5.5 tengo que hacer varios cambios en los trigger's para cambiarme a la version 2.0, cosa que estoy evaluando.... por el momento estoy investigando si en la versión 1.5.5. se puede hacer algo similar....
__________________
"Hemos aprendido a volar como los Pájaros, y a nadar como los Peces, y todavía No aprendemos a vivir como Hermanos". Martin Luther King |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Como darle información a mi base de Datos | servicomp | Firebird e Interbase | 3 | 01-08-2006 18:56:22 |
como darle nuevos aspectos a un trackbar de delphi | rls | Varios | 2 | 16-11-2005 21:26:31 |
Como darle color a un TListColumn? | abracadabra | OOP | 4 | 15-07-2005 17:01:40 |
Tips: Como darle velocidad al IDE en D8 | mamcx | .NET | 0 | 30-09-2004 18:09:45 |
Darle Vida a una IbQuery | Rabata | Conexión con bases de datos | 6 | 16-09-2003 18:48:23 |
|