Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 19-02-2007
vlinares vlinares is offline
Registrado
 
Registrado: mar 2005
Ubicación: Valencia
Posts: 3
Poder: 0
vlinares Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 19-02-2007
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
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:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 19-02-2007
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
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.
Responder Con Cita
  #4  
Antiguo 19-02-2007
vlinares vlinares is offline
Registrado
 
Registrado: mar 2005
Ubicación: Valencia
Posts: 3
Poder: 0
vlinares Va por buen camino
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.
Responder Con Cita
  #5  
Antiguo 19-02-2007
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
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:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #6  
Antiguo 19-02-2007
elguille elguille is offline
Miembro
 
Registrado: ene 2005
Posts: 114
Poder: 20
elguille Va por buen camino
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 ....
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

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


La franja horaria es GMT +2. Ahora son las 03:26:23.


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
Copyright 1996-2007 Club Delphi