Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-07-2010
Ramiro_Hf Ramiro_Hf is offline
Registrado
 
Registrado: jun 2007
Posts: 4
Poder: 0
Ramiro_Hf Va por buen camino
MySQL Tablas y campos tabla

Hola a todos, existe la posibilidad de cargar en un componente delphi las tablas de una BD MySQL.
Y que al seleccionar la tabla en el componente nos llene otro con los nombres de los campos de la tabla seleccionada.
Podríais orientarme como hacerlo.
Gracias
PD Utilizo componentes Zeos y Delphi-6
Responder Con Cita
  #2  
Antiguo 02-07-2010
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Revisa los métodos GetTableNames y GetColumnNames del componente ZConnection.

// Saludos
Responder Con Cita
  #3  
Antiguo 03-07-2010
Ramiro_Hf Ramiro_Hf is offline
Registrado
 
Registrado: jun 2007
Posts: 4
Poder: 0
Ramiro_Hf Va por buen camino
Me da un error al compilar
[Error] Unit1.pas(38): There is no overloaded version of 'GetTableNames' that can be called with these arguments
Es como si el metodo no existiera ¿no?, no tengo manual del componente ¿podría conseguir alguno?
Gracias.
Responder Con Cita
  #4  
Antiguo 03-07-2010
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Y que tal usar un componente TreeView para visualisar tus tablas y cada campos de tus tablas, para MySQL se puede utilizar la siguiente consulta para conocer todas las tablas de una determinada Base de datos:
Código SQL [-]
show tables;
Y para conocer los campos de una determinada tabla se puede hacer así:
Código SQL [-]
Describe Nombre_de_tu_Tabla;
De ahí podemos hacer lo siguiente desde Delphi usando el evento OnClick de un Boton:

Código Delphi [-]
procedure TForm1.Button1Click(Sender: TObject);
var TableName,CampoName:String;
nodo:TTreeNode;
begin
   with ZQuery1 do
     begin
      SQL.Text:='show tables;';
      Open;
      TreeView1.Items.Clear;
        while not Eof do
        begin
          TableName:=Fields[0].AsString;
          nodo:=TreeView1.Items.AddChild(nil,TableName);
              with ZQuery2 do
              begin
                 SQL.Text:='describe '+TableName+';';
                 Open;
                  while not Eof do
                  begin
                    CampoName:=Fields[0].AsString;
                    TreeView1.Items.AddChild(nodo,CampoName);
                    Next;
                  end;
              end;
          Next;
        end;
     end;
end;
En ese caso yo estoy haciendo uso de dos componentes ZQuery para hacer las dos consultas anteriores.
Por supuesto que se le puede adornar un poco más al componente TreeView, poniendo por ejemplo, imagenes a los campos donde se podría poner un icono de una llavecita a los campos Primarios y cualquier otro icono a los demás, eso es cuestion de verificar el cuarto Campo al hacer la segunda consulta anterior mente expuesta arriba, es decir:
Código SQL [-]
 Describe Nombre_de_tu_Tabla; //<-El cuarto campo nos dice si es primario o no .
Espero sea de utilidad.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #5  
Antiguo 05-07-2010
Avatar de AzidRain
[AzidRain] AzidRain is offline
Miembro Premium
 
Registrado: sep 2005
Ubicación: Córdoba, Veracruz, México
Posts: 2.914
Poder: 21
AzidRain Va camino a la fama
Hice una herramienta simple para hacer eso, creo que te puede servir descárgala aquí.
__________________
AKA "El animalito" ||Cordobés a mucha honra||
Responder Con Cita
  #6  
Antiguo 06-07-2010
Ramiro_Hf Ramiro_Hf is offline
Registrado
 
Registrado: jun 2007
Posts: 4
Poder: 0
Ramiro_Hf Va por buen camino
Hola, agradezco mucho las respuestas, en ambos casos las considero muy interesantes y en realidad a poner en práctica.

Por el momento he resuelto el tema con el siguiente codigo:

Mostrar las tablas (Llenando un listbox):

procedure TForm1.NxButtonMostrarClick(Sender: TObject);
var
Query:TZQuery;
sFiltro: String;
begin
if NxRbTodas.Checked then sFiltro := '_xx';
if nxRbSoloProd.Checked then sFiltro := '_xx_2';
ListBox1.Items.Clear;
ListBox2.Items.Clear;
Query:=TZQuery.Create(Self);
Query.Connection := ZConnection1;
Query.SQL.Add('show tables');
try
Query.Open;
while(not Query.Eof) do
begin
if pos(sFiltro, Query.Fields[0].AsString) <> 0 then
ListBox1.Items.Add(Query.Fields[0].AsString);
Query.Next;
end;
finally
Query.Close;
Query.Free;
end;
end;

Una vez llenado el listbox1 donde me muestra las tablas, al acer clic en cualquiera de ellas muestra los campos en el listbox2:

procedure TForm1.ListBox1Click(Sender: TObject);
var
Query:TZQuery;
begin
ZTable1.Active := False;
ZTable1.TableName := ListBox1.Items.Strings[ListBox1.ItemIndex];
ZTable1.Active := True;
ListBox2.Items.Clear;
Query:=TZQuery.Create(Self);
Query.Connection := ZConnection1;
Query.SQL.Add('show columns from '+NxBtnBD.Text + '.' + ZTable1.TableName );
try
Query.Open;
while(not Query.Eof) do
begin
ListBox2.Items.Add(Query.Fields[0].AsString);
Query.Next;
end;
finally
Query.Close;
Query.Free;
end;
end;

Evidente, se puede hacer a lo mejor mas elegante pero con esto he salido del paso. Gracias de nuevo a los que aportaron las ideas y podeis estar seguros que me van a servir y mucho por las caracteristicas de las mismas.
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Relacionar dos tablas con otra tabla sin campos iguales sisne SQL 2 26-04-2010 05:28:16
enviar registros de una tabla a un campo de otra tabla a travez de ciclo IF en MYSQL CLUSTERBIT SQL 8 23-10-2008 15:50:03
SQL con campos de dos tablas mateamargo SQL 7 14-01-2008 15:51:35
Mysql: copiar los campos de una tabla de una base de datos a otra tabla de otra base? patriram MySQL 4 02-11-2007 16:00:24
Como concateno los nombres de los campos de una tabla en mysql Shidalis PHP 35 29-05-2006 20:35:50


La franja horaria es GMT +2. Ahora son las 13:53:43.


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