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 Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 11-09-2007
Avatar de JefeNet
JefeNet JefeNet is offline
Miembro
 
Registrado: ago 2004
Posts: 111
Poder: 20
JefeNet Va por buen camino
ayuda paradox en red e insertar registros

hola tengo una aplicacion con paradox en red, tengo las carpetas de data net y sus vinculos todo bien. mi problema es el siguiente. en una tabla tengo un index autoincremento. el problema lo tengo al insertar un registro en 2 pc a la misma vez. osea si voy a insertar un registro nuevo me eda error de key violation. como resolveria esto?
ejemplo

1- maria
2- pepe
3- carlos

ahora voy a insertar en la pc1 el nombre ricardo que vendria a ser el index numero 4, pero en la pc2 voy a ingresar a manuel que tambien seria el index4. si en las dos pc pigo post a la misma vez, la pc que ejecuto primero guarda el nombre pero la otra pc que llega mas tarde en vez de verificar que el numero 4 ya existe y saltar y crear el numero 5, lo que hace es tratar de postear con el numero 4 (que por logica le corresponderia), pero como ese ya fue ocupado ahi viene y explota el error. soy novato en esto de la red hoy fue que comense a pasar mi aplicacion que en una pc corre muy bien de echo la compañia tiene meses usandola y todo bien pero ahora necesito que sea en red y no he podido. las tablas les tengo en CacheUpdate en true para que cada pc haga sus cambios normalmente pero al aplicar el ApplyUpdates, la pc que lo haga tarde pierde. ayudenme por favor. gracias
Responder Con Cita
  #2  
Antiguo 11-09-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
Creo que te falta en el evento AfterPost del Ttable.

Código Delphi [-]
Table1.FlushBuffers;


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 11-09-2007
MON___ MON___ is offline
Miembro
 
Registrado: abr 2007
Ubicación: Salamanca (España)
Posts: 84
Poder: 18
MON___ Va por buen camino
O quizá en el evento AfterPost:

table1.Refresh;
Responder Con Cita
  #4  
Antiguo 11-09-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
El
Código Delphi [-]
Table1.Refresh;
Habría que hacerlo desde el equipo que consulta para garantizar que ve todos los registros. Es decir antes de abrir cualquier consulta.

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
  #5  
Antiguo 11-09-2007
Avatar de JefeNet
JefeNet JefeNet is offline
Miembro
 
Registrado: ago 2004
Posts: 111
Poder: 20
JefeNet Va por buen camino
ok vopy a probar. es que no se que funcion cumple el FlushBuffers. como dije soy nuevo si alguien me explicara que funcion cumple..

me pondre a trabajar en eso gracias seguire preguntando cualquier cosa
Responder Con Cita
  #6  
Antiguo 11-09-2007
Avatar de eduarcol
[eduarcol] eduarcol is offline
Miembro Premium
 
Registrado: ago 2003
Ubicación: En los estados Zulia y Merida de Venezuela
Posts: 4.151
Poder: 25
eduarcol Va por buen camino
yo pienso que la funcion del flushbuffer es obligar al sistema vaciar los registros del buffer al disco,

yo alguna vez tuve un problema, el sistema no grababa los registros o mejor dicho unos si otros no, pero el amigo marcos me recomendo utilizar esa instruccion y se soluciono, en aquel momento no pude agradecerle ya que de primera no supe si funciono, ahora a tres años del evento aprovecho la ocasion

"gracias marcos"
__________________
...Yo naci en esta ribera del arauca vibr@d0r
Soy hermano de la espuma,
de la garza, de la rosa y del sol...
Viva Venezuela
Responder Con Cita
  #7  
Antiguo 11-09-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
FlushBuffers, lo que hace es descargar la memoria intermedia, es decir cuando ejecutas la orden
Código Delphi [-]
Table1.Post;
los registros quedan en este memoria y si se fuera la luz o se cerrara inesperadamente el programa estos registros se perderían, con esta instrucción fuerzas la descarga del contenido de dicha memoria.

Un Saludo.

De nada Eduarcol, siempre es agradable poder colaborar con alguien.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #8  
Antiguo 12-09-2007
Avatar de JefeNet
JefeNet JefeNet is offline
Miembro
 
Registrado: ago 2004
Posts: 111
Poder: 20
JefeNet Va por buen camino
ok muchas gracias. y ApplyUpdates que funcion cumple?? disculpen las preguntas.
Responder Con Cita
  #9  
Antiguo 12-09-2007
Avatar de eduarcol
[eduarcol] eduarcol is offline
Miembro Premium
 
Registrado: ago 2003
Ubicación: En los estados Zulia y Merida de Venezuela
Posts: 4.151
Poder: 25
eduarcol Va por buen camino
cuando trabajas con cacheupdate los cambios se alamcenan en memoria, para poder grabarlos en la tabla debes utilizar applyupdate, para cancelarlos cancelupdates
__________________
...Yo naci en esta ribera del arauca vibr@d0r
Soy hermano de la espuma,
de la garza, de la rosa y del sol...
Viva Venezuela
Responder Con Cita
Respuesta



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
insertar registros hxochitemol Conexión con bases de datos 1 02-06-2007 01:21:56
Como insertar registros con sql? newbery Firebird e Interbase 1 10-01-2006 14:32:30
Problema al insertar registros en una BD epalacios SQL 4 07-06-2005 19:11:16
Insertar registros en MySQL TONIAM MySQL 0 24-05-2005 15:47:49
Problemas al insertar registros con ADO sanluisme Conexión con bases de datos 0 04-03-2004 10:34:41


La franja horaria es GMT +2. Ahora son las 06:15:38.


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