FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Paradox con vida propia.
Buenos días,
El problema es el siguiente.... He realizado una aplicación que ataco una base de datos en Paradox. Está correctamente configurada la red y funciona aceptablemente bién. Salvo en algunos casos, aleatoriamente, cuando un usuario relaliza una instarción de datos del tipo maestro con lineas de detalle, hasta hay sin problemas. Pero en algunos casos, y ya os digo aleatoriamente, se inventa facturas, cambia lineas de las mismas etc. He revisado el codigo del programa, este es correcto, la configuración de las tarjeta de red, los alias, etc. y todo parece correcto. ¿ alguna pista de donde puede estar el gato ?. Muchas gracias por vuestra ayuda. |
#2
|
||||
|
||||
Pues hombre aún tengo algún sitio en esas circunstancias realizando unas 20.000 facturas por año y nunca se ha inventado ninguna.
En una ocasión había ciertos productos que desaparecian de la lista y sin avisar prepare una tabla bitácora, en donde se registraba que producto se daba de baja, a que hora desde que puesto con clave, resultó que el gerente daba de baja algunos productos porque no tenían movimientos, lo cual ya comprobaba el programa que era así, pues lo que tienen movimientos no deja darlos de baja. Lo que pasa es en un momento dado se acordaba de aquellos productos y cuando veía que no estaban increpaba a las meigas. Un mes más tarde en la tabla había 3 productos con fecha, hora y puesto desde el que se borraron, etc. Si todo está bien configurado, las facturas no pueden eliminarse solas. Lo primero revisa todo, siempre debemos comenzar por cuestionar nuestro propio trabajo antes de echar la culpa a otro. No obstante te voy a decir un motivo por el que pueden desaparecer facturas: Imaginate que tienes un campo autoincremento y que va por 9000 y en un momento dado retocas la tabla, bien creando una nueva y copiándole el contenido de la antigua o por el método que fuere, pues supongamos que con arreglo a los registros que tienes el autoincrmento se queda en 8900. Que va a ocurrir, que las proximas 100 facturas harán desaparecer las que ya tenias en esa situación. Un Saludo.
__________________
Guía de Estilo de los Foros Cita:
|
#3
|
||||
|
||||
Me ocurrió un caso contrario... y es que aparecían lineas que no pertenecían a una factura. Yo le decía firmemente al cliente que eso era imposible, la facturación no podía hacer eso ni en sueños.
El caso es que al borrar una factura, en determinadas circunstancias no se borraban las líneas de detalles, por tanto, al crear una factura nueva, (siendo el número de factura su clave primaria) las antiguas líneas se sumaban a la recien creada factura. Otro tema: Mientras se realiza inserción Maestro-Detalle, basta con dejar un botón habilitado, para que el usuario lo pulse... revisa que no pueda hacer nada que modifique las tablas... por ejemplo, que no pueda añadir una factura mientras se esté realizando la inserción masiva. (añadir, borrar, moverse por la tabla de facturas.... depende de como lo tengas planteado) Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. Última edición por Lepe fecha: 19-02-2007 a las 16:14:05. |
#4
|
|||
|
|||
Cita:
Muchas gracias por tu constestación. Tengo muy claro (despues de 10 años en Delphi) que cuando menos te imaginas has metido la pata en el coidgo, por eso antes nada he revisado el codigo varias veces, pero no he encontrado nada, y además lo mas facil hubiera sido echarle la culpa al usuario diciendo que hay alguien que cambia las facturas, pero antes de eso siempre cuestiono mism programas. De todos modos muchas gracias por tus comentarios. |
#5
|
||||
|
||||
Se me olvidaba comentar un caso. Si estás trabajando en red y dos usuarios estan haciendo una factura a la vez y no le das un número provisonal distinto de factura a cada usuario, entonces se mezclarán las líneas de un usuario con las del otro y al grabar ocurrirá algo parecido a lo que dices. Si es una empresa pequeña y rara vez hay dos usuario haciendo facturas a la vez, puede ocurrir que esto parezca un fenómeno aleatorio.
Usuario 1, está haciendo sin saber si terminará o cancelara la factura: 07/000010 Usuario 2: lo mismo 07/000010 en este momento el detalle de las líneas de los dos se está anexando a la misma factura, usuario 1 cancela Usuario 2 graba. El usuario 2 se encuentra con 3 líneas que el no ha grabado, lo había el usuario uno. Si esta fuera el caso, solución. Yo a cada usuario le doy un número y ese número a la hora de hacer una factura lo multiplico por un número dependiendo el número de usuarios. Situación: Ultima factura:07/000010 Usuario 1 * 10 =10 Factura:=07/000020 Usuario 2 * 10 =20 Factura:=07/000030 Ahora el usuari 1 está haciendo la factura provisional 20 y el 2 la 30 los detalles de uno y otro no colisionan. Usuario 1, cancela la factura, se elimina primero el detalle por ejemplo mediante SQL y luego la factura que como quedó dicho era provisional. Usuario 2 graba, no lo hace con el número 30, pues al momento de confirmar la grabación busca el último número le suma 1 Factura:=07/000011 Graba la cabecera y mediante un Update de se actualizan las líneas al número que les corresponga. Un Saludo.
__________________
Guía de Estilo de los Foros Cita:
|
#6
|
|||
|
|||
Llevo mucho tiempo trabajando en paradox con multiples clientes y configuraciones y nunca se ha inventado nada, lo que es seguro que inventarse facturas y modificar lineas son dos problemas diferentes ....
Vamos que borrar pudiera ser pero modificar o crear registros seguro que es cosa del codigo ... A repasar .... |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Cargar/Guardar un objeto de una clase propia | Uoha | OOP | 7 | 14-05-2007 22:44:01 |
Salvar clase propia en Blob | oscjae | Firebird e Interbase | 4 | 16-02-2007 11:56:39 |
Borrar la propia aplicación con un tiempo | REHome | .NET | 4 | 12-01-2007 19:24:50 |
Controlar eventos de una clase propia | keglevich | OOP | 4 | 15-09-2004 13:58:21 |
Quisiera hacer mi propia instalacion de Firebird 1.0.3.972 | christian | Firebird e Interbase | 1 | 06-07-2003 12:03:28 |
|