Ver Mensaje Individual
  #3  
Antiguo 18-06-2008
Avatar de juanblack
juanblack juanblack is offline
Miembro
 
Registrado: feb 2008
Posts: 12
Reputación: 0
juanblack Va por buen camino
Funciona tambien, pero...

Gracias por la bienvenida y gracias también por tus comentarios y sugerencias boreg, deja te cuento que he probado lo que me recomendaste y efectivamente funciona como cabe esperar, ahora en vez de que la 'chamba' la realice la pc del cliente es el servidor de firebird el que se encarga de asignarle el valor del ZSP al nuevo registro.

Sin embargo me surge la siguiente duda: ¿que pasa si el usuario -por la razón que sea- cancela la inserción?. En ese caso mi clave se habrá incrementado automáticamente pero no se habrá usado y aunque es verdad que en casos como las llaves primarias esto puede no tener gran importancia (pues a los usuarios no les interesa saber de ese valor), ¿que pasa con otro tipo de valores que deben auto incrementarse (y que sí deben conocer los usuarios) como por ejemplo los números de folio?.
De implementarlo con triggers y si los usuarios llevan a cabo altas "falsas" (que cancelan pues) entonces se estaría generando números de folio que no se usarían y al rato me estarían llamando para reclamarme y preguntarme por qué el sistema esta "perdiendo" sus números de folio (sí, asi de especiales son mis usuarios).

Hasta ahora no he encontrado mejor manera de lidiar con este problemita mas que usando el evento onNewRecord (sólo para asignarle un valor temporal cualquiera a este campo CLAVE -cosa que todavía no me convence-), y evento BeforePost ambos del ZTable, pues sé que en este último es (cuando el usuario hace click en el botón 'guardar') cuando se auto incrementa el generador y entonces sí se guardan los datos y todos contentos.

Estoy seguro que debe haber formas mas eficientes de lidiar con el problema, y si alguien sabe cómo y si pudiera darme una idea en mucho se lo agradeceré (llámenme paranoico, pero siento que este método que me saque de la manga me podría traer problemas en el futuro).

De igual manera para los demás casos en que deba generar claves primarias con generadores usare triggers y que el servidor de firebird se encargue de lo demás.

Gracias de nuevo y espero que esta información le sea de utilidad a alguien mas.

Última edición por juanblack fecha: 18-06-2008 a las 15:28:27.
Responder Con Cita