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 28-08-2017
Rc96 Rc96 is offline
Miembro
 
Registrado: ago 2017
Posts: 75
Poder: 7
Rc96 Va por buen camino
Crear arbol mediante registros en una base de datos.

Buenas tardes. estoy haciendo un sistema el cual debo manejar los departamentos de una empresa. tengo en mi BD tres tablas (lvl1, lvl2, lvl3; donde cada tabla solo tiene dos campos : cod y departamento) lo hice de esta forma porque cada nivel tiene distintos departamentos. Estoy intentando traer los datos a un treeview para que quede de la siguinete forma:

+ Nivel1
departamento 1
departamento 2
departamento 3
+ Nivel2
departamento 1
departamento 2
departamento 3
+ Nivel3
departamento 1
departamento 2
departamento 3
El problema es que al traer los datos de cada tabla los inserta en el treeview pero todos en el primer nodo osea "Nivel1" y necesito que cada consulta se muestre segun el nivel que le corresponde. si pudieran decirme como decirle que la consulta de la segunda tabla lvl2 me la muestre en el nodo padre " nivel2".

aca les dejo el codigo delphi que estoy usando:
Código Delphi [-]
procedure Tfrmaggd.Button5Click(Sender: TObject);
var
  nodo0,nodo1,nodo2:Ttreenode;
  n:integer;
  nom,nom1:string;
begin
   with frmvp do
   begin
    FDQnd1.Close;
    FDQnd1.SQL.Text:=('select * from public.estruc_nvl1');
    FDQnd1.Open();
    while not FDQnd1.Eof do
    begin
     nom:=FDQnd1.FieldByName('Departamento').AsString;
     TreeView1.Items.AddChild( TreeView1.Items.Item[0], nom );
     TreeView1.Selected.Expanded := True;
     FDQnd1.Next;
    end;
    end;
      with frmvp do
   begin
    FDQnd2.Close;
    FDQnd2.SQL.Text:=('select * from public.estruc_nvl2');
    FDQnd2.Open();
    while not FDQnd2.Eof do
    begin
     nom1:=FDQnd2.FieldByName('Departamento').AsString;
     TreeView1.Items.AddChild( TreeView1.Items.Item[1], nom1 );
     TreeView1.Selected.Expanded := True;
     FDQnd2.Next;
    end;
    end;
end;
Espero puedan ayudarme. Gracias
Responder Con Cita
  #2  
Antiguo 28-08-2017
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por Rc96 Ver Mensaje
+ Nivel1
departamento 1
departamento 2
departamento 3
+ Nivel2
departamento 1
departamento 2
departamento 3
+ Nivel3
departamento 1
departamento 2
departamento 3
Más lógico sería tener una tabla "Niveles" con los campos "nivel" y "departamento".
Código SQL [-]
create table tbNiveles (
  nivel integer not null,
  departamento integer not null,
  primary key (nivel, departamento)
)
De todas formas, haz una búsqueda por treeview, es un tema tratado en diversas ocasiones.

PD: Si hubieses puesto un título descriptivo, te saldrían temas relacionados. (Algo así como crear árbol de elementos en un treeview).
Responder Con Cita
  #3  
Antiguo 29-08-2017
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Código Delphi [-]
var
  NodoNivel, Nodo : TreeNode;
begin
  with TreeView1.Items do
  begin
     // Creo el nodo "padre"
     NodoNivel := Add(nil, 'Nivel1');
     // Recorro nodos del nivel 1
     FDQnd1.Close;
     FDQnd1.SQL.Text:=('select * from public.estruc_nvl1');
     FDQnd1.Open();
     begin
       // Creo Nodo colgando del NodoNivel.
       Nodo := AddChild(NodoNivel, FDQnd1.FieldByName('Departamento').AsString);

       // Aqui puedo tocar cosas del nodo recien creado.
       Nodo.ImageIndex := -1;

       FDQnd1.Next;
     end

     // Creo el nodo "padre"
     NodoNivel := Add(nil, 'Nivel2');
     // Recorro nodos del nivel 2
     {...}

   
     // Creo el nodo "padre"
     NodoNivel := Add(nil, 'Nivel3');
     // Recorro nodos del nivel 3
     {...}

  end;
end;

Última edición por duilioisola fecha: 29-08-2017 a las 10:05:39.
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
Arbol de estructura de base de datos elrayo76 Varios 1 02-09-2014 19:53:26
Limitar cantidad e registros a crear en una base de datos RedVenom Conexión con bases de datos 25 09-05-2011 21:30:55
filtrar elementos de base de datos en delphi mediante combobox carlossc90 Tablas planas 3 05-06-2008 22:21:10
Crear base de datos mediante componentes de Interbase vivamotos Conexión con bases de datos 5 08-02-2008 09:16:05
¿Cómo conecto la base de datos mediante Interbase en una red local? nuri Firebird e Interbase 2 19-07-2005 17:50:38


La franja horaria es GMT +2. Ahora son las 18:00:02.


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