Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Tablas planas
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
Paradox Error: table cannot be opened for exclusive use

Hola, me sale el error "table cannot be opened for exclusive use" por lo que lei se debe poner Table1.exclusive:=true... pero estoy usando Querys no Table.... como puedo hacer lo mismo pero para un Query? o si hay otra forma de evitar ese error. Gracias desde ya
Responder Con Cita
  #2  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Estaría bien saber, al menos, qué base de datos estás usando
Responder Con Cita
  #3  
Antiguo 18-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
disculpas... paradox y delphi 7
Responder Con Cita
  #4  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Me parece recordar haber leído alguna vez que tienes que cambiar en la configuración LocalShare=True en lugar de False.
Responder Con Cita
  #5  
Antiguo 18-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
hola... probé LocalShare=True pero me dio igual el error... creo que el error me da porque hago un ciclo donde

Código Delphi [-]
While //800 veces
begin
  Qry.Edit; //Edito
  //hago modificaciones  
  Qry.Applyupdate//Aplico 
  Qry.next
end;

no quiero aplicar después del ciclo por miedo a que por un corte de luz o de internet, no me quede guardado nada... es por el tema de la Facturacion Electronica, obtengo el Cae y lo guardo enseguida... si alguien tiene alguna otra sugerencia...gracias desde ya
Responder Con Cita
  #6  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Para eso sirven las transacciones.
Responder Con Cita
  #7  
Antiguo 18-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
transacciones con paradox??? solo uso el TSession, el Query y el Upd
Responder Con Cita
  #8  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
No conozco paradox.
De todas formas es difícil ayudarte si no pones tu código y explicas qué hace exactamente.
El código ese que has puesto de "ejemplo" no sirve de nada.
Responder Con Cita
  #9  
Antiguo 18-06-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola marilinspi.

Se me ocurre que podrías usar un TTimer para el autoguardado, algo parecido a este ejemplo:
Código Delphi [-]
const
   NSEG = 20;

procedure TForm1.FormCreate(Sender: TObject);
begin
  with Database1 do
  begin
    Close;
    AliasName := 'DBDEMOS';
    TransIsolation := tiDirtyRead;
    Open;
  end;

  with Query1 do
  begin
    DatabaseName := 'TEST';
    CachedUpdates:= True;
    UpdateMode   := upWhereChanged;
    Open;
  end;
  // Ej. Guardar datos c/NSEG seg
  Timer1.Interval  := NSEG  * 1000 ; // 20 seg
  Timer1.Enabled   := True;
end;

// Aplicar updates
procedure TForm1.Timer1Timer(Sender: TObject);
begin
  with Query1 do
  begin
    Database1.StartTransaction;
    try
      ApplyUpdates;
      Database1.Commit;
    except
      Database1.Rollback;
      raise;
    end;
    CommitUpdates;
  end;
  ShowMessage('Datos guardados'); // solo para visualizar
end;

// Capturar excepciones
procedure TForm1.Query1EditError(DataSet: TDataSet; E: EDatabaseError;
  var Action: TDataAction);
const
  FLAG = MB_ICONERROR + MB_RETRYCANCEL;
begin
  if MessageBox(Handle, Pchar(E.Message),'', FLAG) = IDRETRY then
    Action := daRetry
  else
    Action := daAbort;
end;
No le pidas mucho lujo al código, estoy seguro que debe haber 100 formas mejores de escribirlo. La verdad es que tuve que leer para refrescar los paupérrimos conocimientos que tengo sobre Paradox , es sólo para acercarte una idea y que espero te sea útil.

De todos modos, y con la mejor de las intenciones, te voy a hacer una sugerencia. Con Paradox vas a vivir reparando y reindexando, es tecnología obsoleta y te va a dar muchos dolores de cabeza.

Existen excelentes gestores, y gratuitos además, como PostgreSQL, Firebird o MySql (por mencionar algunos), que son mil veces superiores. Si todavía estás a tiempo de migrar, huí de Paradox cuanto antes.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 18-06-2015 a las 02:54:43. Razón: agregar comentario al código
Responder Con Cita
  #10  
Antiguo 18-06-2015
Avatar de nlsgarcia
[nlsgarcia] nlsgarcia is offline
Miembro Premium
 
Registrado: feb 2007
Ubicación: Caracas, Venezuela
Posts: 2.206
Poder: 21
nlsgarcia Tiene un aura espectacularnlsgarcia Tiene un aura espectacular
marilinspi,

Cita:
Empezado por marilinspi
...Paradox Error: table cannot be opened for exclusive use...


Cita:
Empezado por delphigroups
The message means that you have the Exlusive property of TbleNrtsPac set to True and some other part of your program or some other program or some other user already has the table open.
Tomado de : Table Cannot be opened for exclusive use

Cita:
Empezado por ecfisa
...Con Paradox vas a vivir reparando y reindexando...Existen excelentes gestores, y gratuitos además, como PostgreSQL, Firebird o MySql...


Debes considerar adicionalmente que:
Cita:
Empezado por Embarcadero
Warning: The Borland Database Engine (BDE) has been deprecated, so BDE will not be enhanced. For instance, BDE will never have Unicode support. You should not undertake new development with BDE. Consider migrating your existing database applications from BDE to dbExpress.
Revisa esta información:
Espero sea útil

Nelson.
Responder Con Cita
  #11  
Antiguo 18-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
muchas gracias a todos por sus respuestas... si efectivamente el error da al aplicar las modificaciones, pero lo raro del caso es que lo hace siempre al aplicar al registro n° 375, es decir.. edito-aplico, edito-aplico, 374 veces lo hace bien al querer hacer la 375 da el error, así que bueno lo termine solucionando así
Código Delphi [-]
    While //800 veces
    begin
      Qry.Edit;
      //Hago modificaciones 
      Qry.ApplyUpdates;
      Qry.Next;
 
      Cont:=cont+1;
      if cont=350 then
      begin
        Cont:=0;
        Qry.Active:=False;
        Qry.ParamByName('numero').Value:=QryNumero.Value;
        Qry.Active:=True;
      end;
    end;

al cerrar y abrir el qry cada tanto deja de dar el error.
Responder Con Cita
  #12  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
¡Por favor!

Me has recordado a un cliente que nos pidió que le cambiésemos la tecla "F1 ayuda" por "F11 ayuda".
¿Por qué quieres cambiarla? y la respuesta fue "porque se me ha roto la tecla F1 del teclado.
Responder Con Cita
  #13  
Antiguo 18-06-2015
marilinspi marilinspi is offline
Miembro
 
Registrado: ene 2007
Posts: 136
Poder: 18
marilinspi Va por buen camino
¿¿¿¿¿?????

Cita:
Empezado por Casimiro Notevi Ver Mensaje
¡Por favor!

Me has recordado a un cliente que nos pidió que le cambiésemos la tecla "F1 ayuda" por "F11 ayuda".
¿Por qué quieres cambiarla? y la respuesta fue "porque se me ha roto la tecla F1 del teclado.
Responder Con Cita
  #14  
Antiguo 18-06-2015
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.021
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Quiero decir que esa no es forma de solucionar el problema, principalmente porque no has solucionado el problema, lo has ocultado debajo de la alfombra, pero surgirá en cualquier momento.
Y lo peor de todo es que hay que averiguar el porqué de un error, no puedes cerrar los ojos para no verlo y seguir como si nada. Es como querer tapar una herida en el brazo llevando siempre manga larga, aunque sea agosto a 40º C. La herida sigue ahí, cúrala.
Es solamente mi opinión.


EDITO: y además nos ocultabas información, creo que nunca dijiste que te ocurría en el 375
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
Paradox To many open table reynaldo Tablas planas 0 06-02-2006 20:06:12
Subir Informaciónde una tabla plana o db a table paradox ginasil Tablas planas 3 27-05-2005 17:49:42
alter table error JoseQ Firebird e Interbase 4 13-08-2004 21:47:45
error en el create table xerkan Firebird e Interbase 3 07-10-2003 16:43:24
Error At end of table del BDE Marina Conexión con bases de datos 6 25-06-2003 11:58:32


La franja horaria es GMT +2. Ahora son las 03:32:21.


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