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 18-07-2017
CFPA86 CFPA86 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Medellin (Colombia)
Posts: 119
Poder: 21
CFPA86 Va por buen camino
Redireccionar Base de Datos

Hola a todos
Tengo una aplicación realizada en D7 y paradox, Esta a su vez tiene un control DataModule el cual contiene unas tablas, todas estas tienen el mismo alias, hasta ahí funciona bien. Para la nueva versión deseo usar las mismas tablas con datos en otra ubicacion, ademas de seguir usando los datos con los que venia. Como hago para que tome en memoria los nuevos datos, después de tener en memoria los viejos?

Alias: Bdempresas
Ubicacion en el disco duro
C:\empresa\DatosViejos\
C:\empresa\DatosNuevos\

Aparte del codigo que uso
Código Delphi [-]
  With Session Do
  // Cerrar el alias de Datos viejos //
  Begin
    DeleteAlias('Bdempresas'):
    AddStandardAlias('Bdempresas','C:\empresa\DatosViejos\','Paradox');
    SaveConfigFile;
  End;

  With Session Do
  // Abrir el alias de Datos Nuevos //
  Begin
    DeleteAlias('Bdempresas'):
    AddStandardAlias('Bdempresas','C:\empresa\DatosNuevos\','Paradox');
    SaveConfigFile;
  End;

Gracias por la colaboración
__________________
Siempre hay un primer momento para todo.

Última edición por ecfisa fecha: 18-07-2017 a las 04:12:42. Razón: Agregar etiquetas [delphi]
Responder Con Cita
  #2  
Antiguo 19-07-2017
Avatar de gatosoft
[gatosoft] gatosoft is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Bogotá, Colombia
Posts: 833
Poder: 21
gatosoft Va camino a la fama
Recuerdo cuando trabajé el tema de paradox... hace unos 10 años, que teniamos un solo programa para acceder a diferentes ambientes de la BD (Desarrollo, Calidad y Producción). La base de datos se enconraba en un "servidor" (carpetas compartidas)

Al iniciar se modificaba la variable Session.ProvateDir

y se cambiaba un parametro del DatabaseEngine via codigo: 'NET DIR'... el driver es uno solo y pueden ser diferentes alias...

Tengo en la memoria(usb) este fragmento de codigo:

Código Delphi [-]
var
  vDriverParams: TStringList;

.... 
 
 Try
   Session.PrivateDir := 'Ruta local (caché)'
 Except
 end;

 vDriverParams := TStringList.Create;
 try
    Try
     if pLimpiar then
       vDriverParams.Add('NET DIR=')
     else
       vDriverParams.Add('NET DIR='+vRutaDB);
     Session.ModifyDriver('PARADOX',vDriverParams);
     Session.SaveConfigFile;
    Except
      Result := 0;
    end;//Try
 finally
   vDriverParams.Free;
 end; //Try


espero que te sirva
Responder Con Cita
  #3  
Antiguo 19-07-2017
CFPA86 CFPA86 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Medellin (Colombia)
Posts: 119
Poder: 21
CFPA86 Va por buen camino
GatoSoft, gracias por tu respuesta la ensayare a ver como me va y les diré.
__________________
Siempre hay un primer momento para todo.
Responder Con Cita
  #4  
Antiguo 19-07-2017
CFPA86 CFPA86 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Medellin (Colombia)
Posts: 119
Poder: 21
CFPA86 Va por buen camino
No me funciona, me podrían dar una mano porfa.
Gracias
__________________
Siempre hay un primer momento para todo.
Responder Con Cita
  #5  
Antiguo 19-07-2017
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.022
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por CFPA86 Ver Mensaje
No me funciona, me podrían dar una mano porfa.
Gracias
Explica por qué no funciona, qué mensaje sale, qué hace exactamente, cómo lo estás haciendo, etc......
Responder Con Cita
  #6  
Antiguo 20-07-2017
CFPA86 CFPA86 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Medellin (Colombia)
Posts: 119
Poder: 21
CFPA86 Va por buen camino
No me saca error en particular, aun desconociendo Plimpiar, mas bien creo yo que puede ser desconocimiento del código (Codigo GataSoft).De todas formas les dire que hago, cree un aplicativo aparte que simulara lo que pretendo, tiene un DataModule conteniendo una tabla (común para ambas empresas), un combobox para empresa1 y empresa2, un Dbgrid que me lista los datos, sea de empresa1 o empresa2, aclaro en el registro del sistema tengo una vble que almacena la ruta de la B.D., corro el aplicativo y me lista los datos de la empresa1, elijo la empresa2 para que me liste estos datos y me sigue mostrando los de la empresa1, Nuevamente corro el aplicativo y ahi si me muestra los datos de la empresa2.

Código Delphi [-]
var
  vDriverParams: TStringList;

....
Procedure TForm1.FormActivate(Sender:TObject);
 begin
   vDriverParams := TStringList.Create;
 end;

Procedure TForm1.ComboBox1Change(Sender:TObject);
 Begin

  DataModule1.TEmpresas.Active := False;
  DataModule1.TEmpresas.Close;

  if (ComboBox1.Text = "Empresa1") then
   begin
     With Session Do
      Begin
         DeleteAlias('Bdempresas'):
         AddStandardAlias('Bdempresas','C:\empresa1\','Paradox');
         vDriverParams.Add('NetDir=C:\empresa1\');
         ModifyDrive('Paradox',vDriverParams);
         SaveConfigFile;
      End;
   End;

  if (ComboBox1.Text = "Empresa2") then
   begin
     With Session Do
      Begin
         DeleteAlias('Bdempresas'):
         AddStandardAlias('Bdempresas','C:\empresa2\','Paradox');
         vDriverParams.Add('NetDir=C:\empresa2\');
         ModifyDrive('Paradox',vDriverParams);
         SaveConfigFile;
      End;
   End;

  DataModule1.TEmpresas.Active := True;
  DataModule1.TEmpresas.Open;

Les agradezco la ayuda que me puedan ofrece y me disculpan por el código.
__________________
Siempre hay un primer momento para todo.

Última edición por Casimiro Notevi fecha: 20-07-2017 a las 15:48:52.
Responder Con Cita
  #7  
Antiguo 20-07-2017
Avatar de gatosoft
[gatosoft] gatosoft is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Bogotá, Colombia
Posts: 833
Poder: 21
gatosoft Va camino a la fama
Veo que tienes mal el parametro NET DIR (Falta el espacio). Pero bueno, es solo una parte y aplica principalmente cuando se trabajan archivos en red (concurrentes)

Veamos otra forma:

En tu Programa debes tener un comoponente TDatabase que tiene una propiedad DataBaseName y ahí defines el alias.

En lugar de hacer el DeleteAlias y addStandarAlias desde la session, intenta modificar los parametros de la base, asi:


Primero en la session defines las rutas (no es obligatorio si no vas a trabajar en red, pero no afecta si lo haces)

Código Delphi [-]
vRutaNetDir:= 'ruta donde ubicas el archivo de control de red'; //puede ser la misma ruta de los datos, el archivo se crea ahi
MySession.NetFileDir := vRutaNetDir
MySession.PrivateDir := 'C:\TEMP'

Código Delphi [-]
vRuta:= 'Lugar donde se ubican los archivos DB';
MyDatabase.Params.Clear;
MyDatabase.Params.Add('PATH=' + vRuta);
MyDatabase.Params.Add('DEFAULT DRIVER=PARADOX');
MyDatabase.Params.Add('ENABLE BCD=FALSE');
MyDatabase.Connected := true;

Espero que te sirva,

NOTA: No olvides encerrar tu código con las etiqueteas respectivas ... [ DELPHI] tu codigo delphi [ /DELPHI]
Responder Con Cita
  #8  
Antiguo 22-07-2017
CFPA86 CFPA86 is offline
Miembro
 
Registrado: sep 2003
Ubicación: Medellin (Colombia)
Posts: 119
Poder: 21
CFPA86 Va por buen camino
Hola a todos nuevamente, !! Lo logré !! con esfuerzo lo logré muchas gracias a todos.
Este es mi codigo final

Código Delphi [-]
Procedure TForm1.ComboBox1Change(Sender:TObject);
 Begin

  DataModule1.TEmpresas.Active := False;
  DataModule1.TEmpresas.Close;
  DataModule1.Tempresas.DataBaseName := "";

  if (ComboBox1.Text = "Empresa1") then
   begin
     With Session Do
      Begin
         DeleteAlias('Bdempresas'):
         AddStandardAlias('Bdempresas','C:\empresa1\','Paradox');
                 
         Close;
         Open;

         SaveConfigFile;
      End;
   End;

  if (ComboBox1.Text = "Empresa2") then
   begin
     With Session Do
      Begin
         DeleteAlias('Bdempresas'):
         AddStandardAlias('Bdempresas','C:\empresa2\','Paradox');
                 
         Close;
         Open;

         SaveConfigFile;
      End;
   End;

  DataModule1.Tempresas.DataBaseName := "Bdempresas";
  DataModule1.TEmpresas.Active := True;
  DataModule1.TEmpresas.Open;
Como ven lo que ,e hacia falta era nada, abrir y cerrar la seccion asi como definir en el databese de la tabla el nuevo alias, muchas gracias nuevamente a todos por su colaboracion, aahhhh y disculpen por el codigo no se como subrayarlo.
Chao
__________________
Siempre hay un primer momento para todo.

Última edición por ecfisa fecha: 22-07-2017 a las 20:42:32. Razón: Agregar etiquetas [DELPHI]
Responder Con Cita
  #9  
Antiguo 22-07-2017
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 CFPA86.

Primero que nada, me alegro que encontraras la solución , también aprovecho para pedirte que cuando incluyas código en tus mensajes lo encierres entre las etiquetas correspondientes de este modo:

para mejorar la visualización.


Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
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
Conectar base de datos Firebird con base de datos Oscommerce 2.3.3 Adriadob Firebird e Interbase 11 31-10-2012 12:28:46
Redireccionar puerto LPT A COM marceloalegre Impresión 0 29-05-2008 01:20:58
redireccionar web angelp4492 Internet 3 22-01-2008 02:57:45
Redireccionar IPTABLES dayrontbs Linux 1 01-08-2006 23:51:48
Redireccionar Eventos Olympus OOP 1 08-11-2004 16:59:21


La franja horaria es GMT +2. Ahora son las 16:27:13.


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