Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 04-06-2003
PEITO PEITO is offline
Registrado
 
Registrado: jun 2003
Posts: 3
Poder: 0
PEITO Va por buen camino
mostrar las tablas de una bd

Tengo una base de datos con unas 30 tablas.
¿Como puedo hacer para que en un combobox insertado en un formulario me aparezcan todas las tablas de dicha base de datos?

¿Si ademas tendo insertado un datasource y un dbgrid, como puedo hacer que cambien los datos segun la tabla que haya elegido en el combobox?

Gracias.
Responder Con Cita
  #2  
Antiguo 04-06-2003
Kafu Kafu is offline
Miembro
 
Registrado: may 2003
Ubicación: Bilbao
Posts: 117
Poder: 22
Kafu Va por buen camino
Depende qué tipo de base de datos sea.
Interbase, Oracle, SQL-server y otros motores del estilo tienen tablas de sistema con los objetos de la BD.
Si hablamos de un paradox, access o por el estilo, creo que tendrás que recorrer los directorios y crearte una lista.
En cuanto a modificar el datasource claro que se puede, en el onchange del combo asignas la propiedad dataset a ese mismo datasource (por ejemplo) y le pones la tabla que hayas seleccionado. Un saludo,



F.T.G.
Responder Con Cita
  #3  
Antiguo 04-06-2003
Kafu Kafu is offline
Miembro
 
Registrado: may 2003
Ubicación: Bilbao
Posts: 117
Poder: 22
Kafu Va por buen camino
Cita:
Si hablamos de un paradox, access o por el estilo, creo que tendrás que recorrer los directorios y crearte una lista.
Olvida esto. Paradox tiene tablas sueltas, pero acces tiene un único mdb. Disculpa la imprecisión.
Responder Con Cita
  #4  
Antiguo 04-06-2003
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 22
andres1569 Va por buen camino
Hola:

El siguiente método de un objeto TSession devuelve en una lista todas las tablas de una base de datos, sin importar que tipo de SGBD sea:

GetTableNames(const DatabaseName, Pattern: string; Extensions, SystemTables: Boolean; List: TStrings);

En la ayuda de Delphi viene explicado su funcionamiento y un ejemplo.

Si rellenas un ComboBox con esas tablas, para que el Grid te muestre los datos de cada tabla, puedes enlazar el DBGrid a un DataSource y éste a un TTable cuyo DatabaseName apunte a esa base de datos. En el OnChange del ComboBox puedes escribir algo así:

Código:
procedure FMainComboBox1Change (Sender: TObject);
begin
  with Table1 do
  begin
    DisableControls;
    try
      Close;
      with TComboBox(Sender) do TableName := Items[ItemIndex];
      Open;   
    finally
      EnableControls;
    end;
  end;
end;
Un saludo
Responder Con Cita
Respuesta



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


La franja horaria es GMT +2. Ahora son las 23:11:45.


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