![]() |
Enlazar base datos con distintos directorios en red
Hola de nuevo, hace un tiempo tuve problemas al poder conectar en red mi programa, gracias a vosotros lo hice con la siguiente sintaxis:
dentro del programa delphi:
en el Archivo ini:
Bien, ahora quería complicarlo un poco más, y es poder manejar varias ejercicios o campañas, los datos de cada campaña están en un directorio distinto así por ejemplo la campaña 2012 están en el Directorio "DATOS12", la campaña 2.013 en el directorio "DATOS13". si yo modifico en el archivo ini manualmente y lo modifico escribiendo:
Accedo bien a los datos de la campaña 2013, pero cómo puedo hacerlo con el programa ejecutándose. Yo al iniciar el programa creo el formulario creo el componente como por ejemplo un combobox para elegir las distintas campañas, pero no sé cómo implementarlo, he intentando buscar información pero no la encuentro. Gracias. |
Yo hago esto:
Un Saludo. |
Constantes del formulario
Función para mostrar el formulario y devolver ruta completa de conexión
En el archivo ini separaría la ruta del nombre de la base de datos
Create del DataModule
|
¡Ostras!, se me acaba de venir un error a la cabeza, lo primero es que faltaría sumarle 1 al itemIndex de la última línea de la función Mostrar y ni por esas está bien, eso sería asumiendo que existen todos los años desde el 2000, pero no es así.
Tal y como está ahora, lo mejor es sutituir por ComboBox1.Text.
El error es por empezar con una solución y acabar con otra... quería mostrar en el combobox "campaña 20XX" y me lié. Para hacerlo de esta segunda forma, mejor sería hacer un array simultáneo al combobox y un procedimiento AddCampana: Variables globales al formulario
Procedimiento AddCampana
Nuevamente la función Mostrar
Saludos. |
Al final he hecho un híbrido a lo que me habéis dicho, he creado un Combobox en el Formulario Principial donde están los distintos ejercicios, 12,13,14...., al ejecutar el programa por primera vez coge el ejercicio que hay en el combobox
Código Delphi [-] procedure TDataModule1.DataModuleCreate(Sender: TObject); Var BaseDeDatos: String; ElIniFile: TIniFile; ejercicio:string; begin // Obtiene la ruta y el nombre de la base de datos ElIniFile := TIniFile.Create(ExtractFilePath(Application.exename)+'BDatos.ini'); BasedeDatos := ElIniFile.ReadString('BD','Path',''); If BasedeDatos = '' then // ShowMessage('Error al cargar Base de Datos') else ibdatabase1.Connected:=false; ejercicio:=FormPrincipal.Combobox1.text; BaseDeDatos:=BaseDeDatos+'Datos'+ejercicio; ibdatabase1.DatabaseName:=BasedeDatos+'\Maestro.ib'; // BaseGeneral es el TIbDatabase y le asigno la ruta de la base de datos segun .ini ibdatabase1.Connected:=true; end; y luego al cambiar el Combobox de ejercicio he hecho lo siguiente: Código Delphi [-]procedure TFormPrincipal.ComboBox1Change(Sender: TObject); Var BaseDeDatos: String; ElIniFile: TIniFile; ejercicio:string; begin // Obtiene la ruta y el nombre de la base de datos dat.DataModule1.IBDatabase1.Connected:=false; ElIniFile := TIniFile.Create(ExtractFilePath(Application.exename)+'BDatos.ini'); BasedeDatos := ElIniFile.ReadString('BD','Path',''); If BasedeDatos = '' then // ShowMessage('Error al cargar Base de Datos') else dat.DataModule1.IBDatabase1.Connected:=false; ejercicio:=FormPrincipal.Combobox1.text; BaseDeDatos:=BaseDeDatos+'Datos'+ejercicio; dat.DataModule1.IBDatabase1.DatabaseName:=BasedeDatos+'\Maestro.ib'; // BaseGeneral es el TIbDatabase y le asigno la ruta de la base de datos segun .ini dat.DataModule1.IBDatabase1.Connected:=true; end; Falta mejorar algunos detalles, pero funciona bien, espero que sea estable en el tiempo que esa es otra Gracias por vuestra ayuda. |
| La franja horaria es GMT +2. Ahora son las 00:11:04. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi