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 24-08-2010
mantraxer21 mantraxer21 is offline
Miembro
 
Registrado: ago 2010
Posts: 94
Poder: 14
mantraxer21 Va por buen camino
Consulta maestro/Detalle (TibTable)

Estimados:
Tengo 2 tablas.

maestro: (Datasource_maestro)
IDMaestro
fecha_1
IDUsuario
Total

detalleDatasource_detalle)

IDDetalle
IDMaestro
IDCliente
IDProducto

Los datos del maestro (fecha = jvdbdatetimepicker), id_usuario (jvdbLuckupCombo), total (DbEdit).

Los datos de detalle IdCliente, idproducto, estan con un dbGrid enlazados cada uno con un combobox para asociarlo al Grid tipo combobox) y el Detalle le asigno el master Source (Datasource_maestro)

Pero luego de esto nosé que más se asigna...

Saludos y espero me ayuden
Responder Con Cita
  #2  
Antiguo 24-08-2010
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.058
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Hola, bienvenido a clubdelphi, te sugiero que leas nuestra guía de estilo para que podamos ayudarte mejor.
Gracias.
Responder Con Cita
  #3  
Antiguo 24-08-2010
Avatar de jafera
jafera jafera is offline
Miembro
 
Registrado: may 2007
Ubicación: Llagostera (Girona)
Posts: 582
Poder: 18
jafera Va por buen camino
Hola

Tambien tienes que enlazar los dos datasets.

Al dataset detalle le tienes que decir que su datasource es el dataset maestro, cosa que veo que ya realizas y al crear un nuevo registro detalle que el id es el del mestro.

Un poco de código no vendría nada mal, siempre se ven mejor las cosas.

Saludos

Josep
Responder Con Cita
  #4  
Antiguo 24-08-2010
mantraxer21 mantraxer21 is offline
Miembro
 
Registrado: ago 2010
Posts: 94
Poder: 14
mantraxer21 Va por buen camino
Trabajo y Logica

Gracias Josep:

Te comento, la siguiente imagen muestra el dibujo que se quiere y que está

Código SQL [-]190.13.167.92/img/Despacho.JPG

La pregunta es cómo le asigno el Id_despacho (master) al detalle ???, para luego en el evento de guardar el "Despacho" no me de errores de violaciones de llaves ?

Si te das cuenta en la Grid, el Cliente y el Producto los tengo unidos como un Combobox, para mejor trabajo del usuario...

En código no hay nada, solo quiero probar con los navigator a ver si funciona y luego meter más mano.

Algo por ahi he leido o visto que al momento de generar o abrir un registro, automaticamente se guarde o quede tomado el Id del Despacho en este caso, para luego asociarlo al campo foráneo del detalle ???

Saludos
Responder Con Cita
  #5  
Antiguo 24-08-2010
Avatar de jafera
jafera jafera is offline
Miembro
 
Registrado: may 2007
Ubicación: Llagostera (Girona)
Posts: 582
Poder: 18
jafera Va por buen camino
No se con que base de datos trabajas, yo en Firebird lo que hago es colocar en el evento onnwerecord de la tabla lo siguiente:

TablaDetalleID.Value := TablaMaestroID.Value;

Donde los ID son los nombres del campo unico de cada tabla para enlazar.

Luego para enlazarlos haces un select de la tabla detalle donde el detalleID = MaestroID.

Espero te sirva

Josep

Última edición por jafera fecha: 24-08-2010 a las 17:59:11.
Responder Con Cita
  #6  
Antiguo 24-08-2010
mantraxer21 mantraxer21 is offline
Miembro
 
Registrado: ago 2010
Posts: 94
Poder: 14
mantraxer21 Va por buen camino
Efectivamente también trabajo con Firebird...

lo realizo altiro y te comento !

Saludos
Responder Con Cita
  #7  
Antiguo 24-08-2010
Avatar de jafera
jafera jafera is offline
Miembro
 
Registrado: may 2007
Ubicación: Llagostera (Girona)
Posts: 582
Poder: 18
jafera Va por buen camino
Acuerdate de incrementar el ID unico del detalle, con un trigger por ejemplo.

Si me pasas la estructura de las tablas te hago un ejemplo rápido

Josep
Responder Con Cita
  #8  
Antiguo 24-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola.

Una forma genérica de asignar maestro/detalle con la estructura que pusiste arriba seria:

Supongamos que tenés declarado
Código SQL [-]
CREATE GENERATOR G_MAESTRO;
CREATE GENERATOR G_DETALLE;

CREATE TABLE MAESTRO (
  IDMAESTRO INTEGER NOT NULL,
  FECHA_1 DATE,
  IDUSUARIO INTEGER,
  TOTAL NUMERIC(15,2),
  CONSTRAINT MAESTRO_PK PRIMARY KEY (IDMAESTRO),
);

CREATE TABLE DETALLE (
  IDDETALLE INTEGER NOT NULL,
  REFMAESTRO INTEGER NOT NULL,
  IDCLIENTE INTEGER NOT NULL,
  IDPRODUCTO INTEGER NOT NULL,
  CONSTRAINT MAESTRO_PK PRIMARY KEY (IDDETALLE),
  FOREIGN KEY(REFMAESTRO) REFERENCES MAESTRO(IDMAESTRO)
);

Triggers para generators:
Código SQL [-]
SET TERM ^;
CREATE TRIGGER MAESTRO_BI FOR MAESTRO ACTIVE BEFORE INSERT OR UPDATE
AS
BEGIN
  IF (NEW.MAESTRO_ID IS NULL) THEN
     NEW.MAESTRO_ID = GEN_ID(G_MAESTRO,1);
END^

CREATE TRIGGER DETALLE_BI FOR DETALLE ACTIVE BEFORE INSERT OR UPDATE
AS
BEGIN
  IF (NEW.DETALLE_ID IS NULL) THEN
     NEW.DETALLE_ID = GEN_ID(G_DETALLE,1);
END^
SET TERM ;^

Y esté asignado en 'MAESTRO':

Cita:
.IBDataSetMaestro -> TABLE MAESTRO
.dsMaestro -> IBDataSetMaestro
.GeneratorField -> G_MAESTRO

Y en 'DETALLE':

Cita:
.IBDataSetDetalle -> TABLE MAESTRO
.dsDetalle -> IBDataSetDetalle
.GeneratorField -> G_DETALLE

Debería funcionar si:

Cita:
.IBDataSetDetalle.SelectSQL:= 'SELECT * FROM DETALLE WHERE REFMAESTRO = :IDMAESTRO';
.IBDataSetDetalle.DataSource:= dsMaestro;

Saludos.

Última edición por ecfisa fecha: 24-08-2010 a las 18:58:06.
Responder Con Cita
  #9  
Antiguo 24-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola de nuevo.

Perdón ahora veo que usas IBTables...

Es mucho mas fácil que con IBDataSet aunque menos eficiente.
Sólo debés ajustar en el IBTable DETALLE:

Cita:
.Database
.TableName -> DETALLE
.MasterSource -> dsMaestro
.MasterFields: REFMAESTRO -> IDMAESTRO
Y tenés establecida la relación maestro/detalle.

Saludos.
Responder Con Cita
  #10  
Antiguo 24-08-2010
mantraxer21 mantraxer21 is offline
Miembro
 
Registrado: ago 2010
Posts: 94
Poder: 14
mantraxer21 Va por buen camino
El Ultimo Post Me Funciona Un 90 Creo.

Pues En El Primer Dbnavigator (maestro) Al Momento De Crear Un Nuevo Registro, Me Permite Realizarlo, El Tema Es Que Cuando Pasa A La Grid (detalle) Y Quiero Guardar 1 Registro (fila) Dice Que El Id_detalle Debe Contener Un Valor (must Have A Value).

Creo Que Seria Bueno Eliminar El 2º Dbnavigator Y Dejar Al Usuario Que Al Momento De Generar Una 2 Fila En La Grid (con Tabulador Por Ejemplo) Se Vayan Generando !

Saludos
Responder Con Cita
  #11  
Antiguo 24-08-2010
mantraxer21 mantraxer21 is offline
Miembro
 
Registrado: ago 2010
Posts: 94
Poder: 14
mantraxer21 Va por buen camino
Cita:
Empezado por mantraxer21 Ver Mensaje
El Ultimo Post Me Funciona Un 90 Creo.

Pues En El Primer Dbnavigator (maestro) Al Momento De Crear Un Nuevo Registro, Me Permite Realizarlo, El Tema Es Que Cuando Pasa A La Grid (detalle) Y Quiero Guardar 1 Registro (fila) Dice Que El Id_detalle Debe Contener Un Valor (must Have A Value).

Creo Que Seria Bueno Eliminar El 2º Dbnavigator Y Dejar Al Usuario Que Al Momento De Generar Una 2 Fila En La Grid (con Tabulador Por Ejemplo) Se Vayan Generando !

Saludos
Nose si alguien puede ayudar remotamente , acá ocupo el team viewer
Código SQL [-]
mauriciodurant@hotmail.com
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
Consulta maestro-detalle, DBExpress con MySQL Josepo Conexión con bases de datos 6 30-11-2007 17:59:06
Consulta maestro detalle. jplj SQL 5 30-05-2007 20:24:14
Consulta sobre maestro detalle ilichhernandez Conexión con bases de datos 0 18-05-2007 19:13:06
Problema con consulta en Maestro-Detalle TrUnkS SQL 2 11-10-2006 00:20:47
Consulta Maestro Detalle Acker SQL 1 10-07-2006 19:25:58


La franja horaria es GMT +2. Ahora son las 19:21:15.


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