FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Saltos en secuencia de numero de factura....
Un saludos colegas del club, tengo una aplicacion hecha en delphi 2009 y firebird 2.1 con ibx.
Me esta pasando algo muy raro ultimamente, para generar mi numero de factura lo hago de la siguiente manera:
Nota: Derrepente me da saltos y me deja hueco en numero. Realmente no se aque se deba, solo busco al maximo en la consulta, no se si seran los componentes ibx esto esta muy raro. Cuando hago ciertas prueba generando numero de factura no ocurre y en produccion si. Nota2: se que lo generadores me dejan muchos huecos y tambien he notado que cuando esto pasa produce esos saltos no se como controlarlos, alguna ayuda les agradesco.
__________________
ronimaxh Rep. Dominicana Última edición por ronimaxh fecha: 15-01-2010 a las 03:07:31. |
#2
|
||||
|
||||
¿El programa permite eliminar una factura?, ¿puede que sea el problema?
|
#3
|
||||
|
||||
Hola.
No soy muy bueno leyendo código ajeno, pero creo que buscas el número máximo y le sumas uno. Yo utilizo una tabla en la DD.BB con nombre (nombre del comprobante) y valor, que es el último valor. Cuando se confirma la venta, genero el número de comprobante. Accediendo al valor por medio de un dataset y asignado el nuevo valor. Es útil para el caso de concurrencias. Con éste método es muy poco probable que haya huecos en los números de comprobantes. Si querés te mando un mail con un apunte que lo explica muy bién. Es de un profesor de mi facultad. Saludos a todos. |
#4
|
|||
|
|||
Gracias por contestar, la facturas no se eliminan solo se anulan.
Cañones favor de enviar el correo que ayuda reforzar. Cualquier colega que pueda ayudar agradezco.
__________________
ronimaxh Rep. Dominicana |
#5
|
||||
|
||||
El primer problema que tienes es que generas el codigo en el cliente y no en la BD.
Deberias usar un generador. Definitivamente. La razon del porque pueden haber "huecos" si hay acceso multiusuario es que varios clientes pueden solicitar una nueva numeracion al tiempo. Dos clientes solicitan el siguiente maximo y a ambos se les da la misma respuesta. Luego, el usuario se cansa, anula, abandona o cancela. Para hacer de un cuento largo uno corto, estos códigos deben ser generados en el instante preciso del INSERT. No se deben generar antes que le de al usuario tiempo de llenar datos y luego cancelar la acción. Eso da huecos. El uso de la tabla no necesariamente te resuelve el asunto. Es el *momento* elegido para hacer el avance del consecutivo y si *bloqueas* la generación del consecutivo teniendo presente las implicaciones del acceso recurrente. En términos de programación OO lo que estas buscando es un Singleton (http://es.wikipedia.org/wiki/Singleton), un único punto de acceso y alteración de datos. Seria algo asi, traducido de OO a como es un manejo de datos: *TODO DENTRO DE LA BD, EN UNA TRANSACCION* Código:
BLOQUEAR FILA/TABLA/GENERADOR DE NUMERACION OBTENER SIGUIENTE AUMENTAR DESBLOQUEAR RETORNAR
__________________
El malabarista. Última edición por mamcx fecha: 15-01-2010 a las 03:20:41. |
#6
|
|||
|
|||
Gracias amigo por responder, ese codigo que puse es llamado en el instante del inicio del insert frmprincipal.genera_numero_fact(esta es una rutina).
Tambien los generadores dejan huecos.
__________________
ronimaxh Rep. Dominicana |
#7
|
||||
|
||||
¿Y en qué consiste esa anulación?
|
#8
|
|||
|
|||
las facturas cuando se anulan solo cambia a status I (inactiva).
__________________
ronimaxh Rep. Dominicana |
#9
|
||||
|
||||
¿Cuantos usuarios trabajan de forma concurrente?
¿En qué momento insertas la factura? ¿Utilizas transacciones? ¿La insertas utilizando SQL o componentes DataAware?
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
Herramientas | Buscar en Tema |
Desplegado | |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
fecha y numero de factura | lis983 | Varios | 3 | 13-07-2008 01:31:23 |
numero de factura | josi | Varios | 7 | 06-06-2008 15:55:59 |
Problema Con campo Numero factura | josejose | Varios | 1 | 01-02-2007 15:44:46 |
Fallo Nº Factura y Linea Factura | CarmaZone | Tablas planas | 5 | 26-05-2005 11:17:19 |
saltos en tabulador. | kwan | Varios | 3 | 09-01-2004 02:25:17 |
|