PDA

Ver la Versión Completa : Como importar datos para anexarlos a mi BD


JoAnCa
26-09-2008, 20:31:39
Hola a todos
Necesito saber de que forma puedo importar los datos de una tabla (o varias) de access para anexarlos a otras tablas en otra BD de access tambien.
Las tablas origen son iguales a las tablas destino.

El objetivo de mi soft es:
- Cada brigada tiene su BD con los informes de produccion, y deben exportarlos a la direccion de la Empresa (no hay problema en esta parte).
- En la empresa se importan cada una de estas BD (se anexan a la BD principal), para totalizar los datos y hacer los resumenes.

Espero haberme explicado bien.
Trate de hacerlo leyendo cada registro en la tabla origen y despues copiando el registro en la tabla destino, pero es muy engorroso cuando son muchos campos en la tabla, se que debe haber una forma mejor, por eso les pido la ayuda.

:rolleyes:
Saludos

droguerman
26-09-2008, 22:29:02
Has probado usar tablas vinculadas dentro de access?

opcion 2: usar servidores vinculados con sql server o crear una consulta usando openDataSource

JoAnCa
27-09-2008, 15:19:14
Has probado usar tablas vinculadas dentro de access?

opcion 2: usar servidores vinculados con sql server o crear una consulta usando openDataSource

No he vinculado tablas dentro de access, pues no veo como me pueda ayudar eso.

De que forma se pueden anexar los datos usando servidores vinculados con sql? :confused:

Caral
27-09-2008, 16:28:16
Hola
Creo que lo que se puede hacer es obtener la informacion de cada base de datos en un form y hacer los reportes sin necesidad de pasar los datos a otra base de datos.
Para hacer lo que quieres se tendria que definir los campos por diferencia, de lo contrario copiaria todo encima de la informacion que ya se tiene.
Saludos

JoAnCa
29-09-2008, 16:16:20
A ver si me explico mejor:

Lo que quiero hacer con mi programa delphi, es lo mismo que hace Access con las consultas de datos anexados, seleciono una tabla y me anexa los datos en otra tabla.
El hecho es que las tablas para anexar pueden tener cualquier nombre, por eso no puedo ponerlas vinculadas en access, ni predeterminarlas al importar los datos. Tengo que buscarlas con el Dialogo Abrir.

Cuando una brigada me entrega su BD, con la opcion "Importar" de mi programa agrego sus datos a mi BD, en la llave correspondiente al nombre de la brigada, si los datos existen que los reemplace, si no los adiciona. Cuando entregue otra brigada, hacer lo mismo, y anexarlo a mi BD a la llave correspondiente a esa otra brigada.
De esta forma yo tendria los datos de todas las brigadas en una unica BD, y cada brigada tendria solo sus respectivos datos.

Cual seria la forma equivalente a la consulta de datos anexados de access?
Como hacerlo con una SQL o con otra forma?

Saludos

JoAnCa
01-10-2008, 19:42:09
Como seria la instruccion SQL para anexar datos?
:confused: :rolleyes:

JoAnCa
06-10-2008, 21:45:11
Ya encontre como anexar datos de otra tabla en otro mdb



BDOrigen:='NombreTabla';
BDDestino:='NombreMDB.NombreTabla';

.....

with ADOQuery1.SQL do
begin
Clear;
Add('INSERT INTO ' + BDDestino + '(Campo1, Campo2, Campo3, etc)');
Add('SELECT Campo1, Campo2, Campo3, etc');
Add('FROM ' + BDOrigen);
Add('WHERE ' + CadFiltroSQL);
end;
ADOQuery1.ExecSQL;
end;

:)

ledesmarc
21-11-2008, 12:18:11
Hola, yo tengo un inconiente algo parecido, el tema es que mi aplicacion esta instalada en varios estudios, y lo que necesito es poder generar un archivo de datos y luego poder importarlos de la misma aplicacion pero en otro estudio, pense hacerlo con un excel pero se complica porque hay varias versiones y con algunas no funciona bien..
Asi que por favor pido que me den una mano alguna buena idea componentes....
Desde ya muchas gracias..

Marcos.-

ledesmarc
21-11-2008, 12:29:53
Aclaro la idea, si bien lo de importar de la base de datos es buena idea... a lo que me refiero es poder exportar de mi sistema solo algunos datos, porque el tamaño de la base completa es demasiado grande para estar enviando por email, ya que esto va a ser algo de todos los dias...

Saludos