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

 
 
Herramientas Buscar en Tema Desplegado
  #4  
Antiguo 20-07-2007
[pepon386] pepon386 is offline
Miembro Premium
 
Registrado: ene 2005
Ubicación: Valencia
Posts: 68
Poder: 20
pepon386 Va por buen camino
En mi empresa tubimos el mismo problema cuando empezamos a usar Citrix (una variante de Terminal Server). El problema radica (si mal no recuerdo) en que por defecto todos intentan usar el mismo directorio temporal para la sesión. Te adjunto un ejemplo para abrir una base de datos en AS/400, pero con pocos cambios podrás usarlo para archivos Paradox.

Código Delphi [-]
procedure TDMMain.DataModuleCreate(Sender: TObject);
var
  Tmp: PChar;
  FDirTemp: string;
  Condicionantes: string;
begin
  IniciaFormatos;
  if Database.Connected then
    Database.Close;
  GetMem(Tmp, 255);
  GetTempPath(255, Tmp);
  FDirTemp := Trim(string(Tmp)) + Copy(ExtractFileName(ParamStr(0)), 1,
    Length(ExtractFileName(ParamStr(0))) - Length(ExtractFileExt(ParamStr(0))));
  FreeMem(Tmp);
  if not DirectoryExists(FDirTemp) then
    CreateDir(FDirTemp);
  Session.PrivateDir := FDirTemp;
  
  try
    FLogin := TFLogin.Create(Application);
    if FLogin.ShowModal = mrOk then
    begin
      CfgInicio.Usuario := FLogin.Usuario.Text;
      Application.ProcessMessages; // necesario para el Splash Form
      ConectaBD(Database, FLogin.Usuario.Text, FLogin.Password.Text)
    end;
  finally
    FLogin.Free;
  end;
  if not Database.Connected then
  begin
    MessageDlg('No se pudo iniciar la aplicación', mtError, [mbOk], 0);
    Application.Terminate;
  end;
end;
 
 
procedure TDMMain.ConectaBD(DB: TDatabase; const UserID, Password: string);
begin
  DB.AliasName := 'AS400';
  DB.TransIsolation := tiReadCommitted;
  DB.Params.Clear;
  DB.Params.Add('user name=' + UserID);
  DB.Params.Add('password=' + Password);
  try
    DB.Open;
  except
    on e: exception do MessageDlg('Se ha producido el siguiente error: ' + #13#10 + e.Message,
      mtError, [mbOk], 0);
  end;
end;

Para que funcione correctamente debes de tener en el TDataModule un obteto TDatabase y un objeto TSession

Última edición por pepon386 fecha: 20-07-2007 a las 10:16:19.
Responder Con Cita
 



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
Terminal server dape Varios 5 15-05-2007 06:37:10
Printers Terminal Server eureka Impresión 2 28-07-2006 14:40:33
BDE En terminal server keys Conexión con bases de datos 3 24-10-2005 12:19:20
Problemas con Terminal Server Win 2003 Server El_Perrito Windows 0 16-10-2004 19:53:45
Terminal Server chavi Varios 4 24-06-2003 21:31:54


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


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