Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Paradox con vida propia. (https://www.clubdelphi.com/foros/showthread.php?t=40496)

vlinares 19-02-2007 13:00:58

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.

marcoszorrilla 19-02-2007 15:44:27

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.

Lepe 19-02-2007 16:10:20

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

vlinares 19-02-2007 18:36:39

Cita:

Empezado por marcoszorrilla
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.


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.

marcoszorrilla 19-02-2007 19:59:33

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.

elguille 19-02-2007 20:23:50

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 ....


La franja horaria es GMT +2. Ahora son las 07:05:49.

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