Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MySQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 21-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Zeoslib TZTables

Buenas,

Quisiera haerles una consulta.
Tengo dos Tablas, Tabla_01 y Tabla_02, la Tabla_01 es la tabla padre y la Tabla_02 es la tabla hija.

Ahora, si en la Tabla_01 estoy en le regisitro 5 y en la Tabla_02 en el registro 10, pero cuando grabo el registro 5 de la Tabla_01, la posicion de la Tabla_02 se va hasta el final ¿porque sucede eso? y como podria evitarlo.

Conclusion si yo grabo un registro en la Tabla_01 se mueve el registro de la Tabla_02 hasta el final porque??

Gracias
Responder Con Cita
  #2  
Antiguo 21-09-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Hola Connor.

Cita:
Empezado por connor Ver Mensaje
si yo grabo un registro en la Tabla_01 se mueve el registro de la Tabla_02 hasta el final porque??
Asumo que con grabar te refieres a llamar al método Post del componente. Pues sí que es un comportamiento raro, pero nada que no pueda investigarse con el depurador de Delphi.

No conozco gran cosa de la biblioteca ZeosLib, pero algo que se me ocurre es que uses el evento AfterScroll de la tabla detalle para colocar en él un punto de ruptura (tecla F5), el cual esté habilitado en el momento de hacer el guardado del registro maestro.

Esto para que, una vez detenido el programa en ese punto, hagas aparecer la pila de llamadas (Ctrl+Alt+S) y con ella conocer el camino que siguió el programa (que rutinas se fueron llamando en cadena), desde que hiciste el Post hasta que se llamó al evento AfterScroll (suponiendo que este evento sí es disparado cuando la tabla detalle se posiciona en el último registro).

¿Podrías hacer lo anterior y decirnos qué ves? De preferencia copia aquí la pila de llamadas que te aparece (una imagen de la misma si te resulta más fácil), para que podamos echarle un vistazo.

Saludos.

Al González.
Responder Con Cita
  #3  
Antiguo 21-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Gracias por responder,

No se como hacer lo que dices, y si, hago post en la tabla padre y en la tabla hija el registro se va hasta el final, el registro deberia quedarse en su posicion actual y no irse hasta el final, solo deberia irse hasta el principio si hiciera un scroll y no hasta el final. Esto no se como resolverlo, es un comportamiento raro como dices no se que hacer.

Otro error con los componentes zeoslib son que al insertar un nuevo registro no se refrescan las grillas se quedan con los datos anteriores, tengo que usar un afterInsert y refrescarlas manualmente.
Responder Con Cita
  #4  
Antiguo 21-09-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Empezado por connor Ver Mensaje
Gracias por responder,

No se como hacer lo que dices...
¿Cuál parte en específico? ¿Qué has investigado de lo que no comprendes? Te animo a desglosar tus dudas, pregunta.

Cita:
Empezado por connor Ver Mensaje
Otro error con los componentes zeoslib son que al insertar un nuevo registro no se refrescan las grillas se quedan con los datos anteriores, tengo que usar un afterInsert y refrescarlas manualmente.
Tema nuevo, hilo nuevo.
Responder Con Cita
  #5  
Antiguo 21-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Mira ya decubri el error de porque pasaba eso, el problema es que yo pintaba los DDGrids en el evento DBGrid1DrawColumnCell y le quite y ahora funciona muy bien, el problema es que ahora tengo mis DBGrids Standard como vienen, la idea era "Pintar la fila seleccionada del DBGrid", ahi estaba el problema.

Código Delphi [-]
 
procedure TForm_BeEMPPRJ.DBGrid_MTRPRTDrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
begin
  // Init
  DBGrid_MTRPRT.Canvas.Font.Style := [];
  DBGrid_MTRPRT.Canvas.Font.Color := clWindowText;
  if (DBGrid_MTRPRT.DataSource.DataSet.RecNo = MTRPRT_RecNo) then
    DbGrid_MTRPRT.Canvas.Brush.Color := $00EFD3C6
  else
    DbGrid_MTRPRT.Canvas.Brush.Color := clWindow;
  if (gdSelected in State) and
     (DBGrid_MTRPRT.Focused) then
  begin
    DBGrid_MTRPRT.Canvas.Font.Color := clWindow;
    DbGrid_MTRPRT.Canvas.Brush.Color := clHighlight;
  end;
  // Continue
  DBGrid_MTRPRT.DefaultDrawColumnCell(Rect, DataCol, Column, State);
end;

La variable "MTRMRD_RecNo" la actualizaba en el evento Dataset "DataChage" y el DBGrid lo refrescaba en el Evento AfterScroll, quite los eventos "DrawColumnCell" y ahora si funciona claro quite todos los eventos de pintado de grilla.

Como Podria pintar un DBGrid pero solo la Fila seleccionada, he visto ejemplos aca pero no funcionan alguna idea.


Gracias

Última edición por RebeccaGL fecha: 21-09-2010 a las 19:55:04.
Responder Con Cita
  #6  
Antiguo 21-09-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
A simple vista no veo la relación entre ese evento y el posicionamiento de la tabla detalle en el último registro.

Sería muy útil que hicieras lo que te sugerí primero. En este foro, en la ayuda y en la Red en general encuentras muchos temas sobre los puntos de ruptura (breakpoints) y la pila de llamadas (call stack) del depurador de Delphi. Pero a lo visto no has estimado esa sugerencia que muy probablemente daría con la clave de por qué ocurre tal efecto.
Responder Con Cita
  #7  
Antiguo 22-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Volvio a pasarme esto no se que sera, aca pongo una imagen del debug.

http://img243.imageshack.us/img243/9153/32598529.jpg

Código Delphi [-]
 
procedure TForm_BeEMPPRJ.Button1Click(Sender: TObject);
begin
  // SAVE_Status
  Table_STDANO.Edit;
  Table_STDANO.FieldByName('IE').AsString := vkc_0042;
  Table_STDANO.Post;
end;

En este codigo hago Post en la tabla Año y me manda las posiciones de los registros mes y dias por donde sea.

Table_STDANO es la tabla padre Table_STDMES es hija de la Table_STDANO y Table_SDTDIA es hija de la Tabla_STDMES.

Table_STDANO >> Table_STDMES >> Table_STDDIA

Ejemplo. Si estoy en el año 2010 mes=Septiempbre y dia=22, entonces hago post en Table_STDANO y la Table_STDMES se posiciona en culaquier mes y pierdo el mes de Septiembre igual con la Table_STDDIA.

He revisado todos los Eventos de tablas dbgrids pero nada, la verdad no se que esta pasando, o seran que los componentes zeos estan con fallas.


Saludos
Responder Con Cita
  #8  
Antiguo 22-09-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Empezado por connor Ver Mensaje
...hago post en Table_STDANO y la Table_STDMES se posiciona en cualquier mes...
Ah, ¿entonces no necesariamente la tabla detalle se va al último registro? Puede quedar en cualquiera, por lo que dices.

Gracias por seguir proporcionando estas pistas, Connor. La imagen que pusiste es de la ventana CPU, pero en este caso sería más útil la ventana Call Stack (menú View-Debug Windows-Call Stack).

¿Entonces sí pusiste un punto de ruptura en el evento AfterScroll de Table_STDMES, y en él se detiene el programa cuando guardas el registro en Table_STDANO?

Saludos.

Al.
Responder Con Cita
  #9  
Antiguo 22-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Al Gonzales, gracias por responder, no se mucho de los debugs y los calls Backs me bajare un manual para aprender a usarlos.

Pero ya resolvi el problema lo que hise fue eliminar la Tabla_STDANO y su DataSource, y la volvi a crear y todo funciona bien, yo pienso que debe haberse colado algun codigo extraño en la tabla que la hacia trabajar mal pero al crearla de nuevo los problemas desparecieron.

Lo que si me gustaria mucho es, si me puedes ayudar a pintar "solo la fila seleccionada de un DBGrid" no usar el options sino por medio de "OnDrawColumnCell".


Saluditos,
Responder Con Cita
  #10  
Antiguo 22-09-2010
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
Se ha tratado muchas veces ese tema, si haces una búsqueda por clubdelphi encontrarás bastante información, básicamente debes escribir algo así:


Código Delphi [-]
procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect; 
  DataCol: Integer; Column: TColumn; State: TGridDrawState); 
begin
   if Column.Field = ClientDataSet1SALDO then   // el campo que queremos controlar
     if ClientDataSet1SALDO.AsCurrency < 200 then    // en este caso si el valor es menor de 200
     begin 
       DBGrid1.Canvas.Font.Style := 
         DBGrid1.Canvas.Font.Style + [fsBold];   // pintamos en 'negrita'
       DBGrid1.Canvas.Font.Color := clRed;     // y en color rojo
       DBGrid1.DefaultDrawDataCell(rect,Column.Field,State); // pinta el texto 
     end;
end;

Y nada más.
Responder Con Cita
  #11  
Antiguo 23-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
Hola,

Mira te explico mejor lo que deseo hacer es pìntar la "Fila seleccionada por el focus", si estoy en el registro 10 se pinta la fila 10 si estoy en el registro 15 se pinta la fila 15, pintar deacuerdo a la posicion del registro fisico.
Responder Con Cita
  #12  
Antiguo 23-09-2010
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
Pues entonces más fácil, sin condicionantes:

Código:
procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
    DataCol: Integer; Column: TColumn; State: TGridDrawState);  
begin
  DBGrid1.Canvas.Font.Style := DBGrid1.Canvas.Font.Style + [fsBold];
  DBGrid1.Canvas.Font.Color := clRed;
  DBGrid1.DefaultDrawDataCell(rect,Column.Field,State);
end;
Y nada más
Responder Con Cita
  #13  
Antiguo 23-09-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
No eso no, mira este ejemplo.

Código Delphi [-]
 
procedure TForm_BeEMPPRJ.DBGrid_CVMMOVDrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
begin
  // Init
  DBGrid_CVMMOV.Canvas.Font.Style := [];
  DBGrid_CVMMOV.Canvas.Font.Color := clWindowText;
 
  if (DBGrid_CVMMOV.SelectedRows.CurrentRowSelected)  then
    DbGrid_CVMMOV.Canvas.Brush.Color := $00EFD3C6
  else
    DbGrid_CVMMOV.Canvas.Brush.Color := clWindow;
 
  if (gdSelected in State) and
     (DBGrid_CVMMOV.Focused) then
  begin
    DBGrid_CVMMOV.Canvas.Font.Color := clWhite;
    DbGrid_CVMMOV.Canvas.Brush.Color := clHighlight;
  end;
 
  // Continue
  DBGrid_CVMMOV.DefaultDrawColumnCell(Rect, DataCol, Column, State);
end;

Algo asi como tener todo el Brush toda la barra del DBGrid pintado en la posicion del registro en curso.
Pero este ejemplo no funciona.

Última edición por RebeccaGL fecha: 23-09-2010 a las 23:51:12.
Responder Con Cita
  #14  
Antiguo 07-10-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
!!!Me volvio a salir este mismo errorrrrrrrrrrrrrrrrr. ayudaaaaaaaaa..

En este codigo hago Post en la tabla Año y me manda las posiciones de los registros mes y dias por donde sea.

Table_STDANO es la tabla padre Table_STDMES es hija de la Table_STDANO y Table_SDTDIA es hija de la Tabla_STDMES.

Table_STDANO >> Table_STDMES >> Table_STDDIA

Ejemplo. Si estoy en el año 2010 mes=Septiempbre y dia=22, entonces hago post en Table_STDANO y la Table_STDMES se posiciona en culaquier mes y pierdo el mes de Septiembre igual con la Table_STDDIA.

He revisado todos los Eventos de tablas dbgrids pero nada, la verdad no se que esta pasando, o seran que los componentes zeos estan con fallas.

Pagare $$$ por la ayuda pero diganme cual es el problema y como solucionarlo, por favor....
Responder Con Cita
  #15  
Antiguo 07-10-2010
Avatar de tgsistemas
tgsistemas tgsistemas is offline
Miembro
 
Registrado: dic 2003
Ubicación: Barcelona
Posts: 149
Poder: 21
tgsistemas Va por buen camino
connor,
disculpa si digo una tonteria pero personalmente prefiero utilizar qrys en lugar de tables para el acceso a los datos.
En tu caso crearía un qrySTDANO y un qrySTDDIA asociado al anterior, bastaria con refrescar el qrySTDDIA cuando se produzcan cambios (update, delete, browse...) en el qrySTDANO.
Por lo que entiendo de tus explicaciones, creo que no debes tener bien la relación master/detail en los componentes.

Para el tema de pintar los dbgrids hay muchos ejemplos en el foro como te decía Casimiro incluso componentes como los GLib de Neftali

Saludos
__________________
Toni | blog
Responder Con Cita
  #16  
Antiguo 07-10-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

Pues yo para pintar la fila que tiene actualmente el foco lo hago así:
Código Delphi [-]
procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
      if (gdSelected in State) then //si la actual columna está seleccionada
       begin
        (Sender as TDBGrid).Canvas.Brush.Color:=clBlack;//pinto el fondo
        (Sender as TDBGrid).Canvas.Font.Color:=clRed;//cambio el color de la fuente                 
       end
end;
Espero sea de ayuda....
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7

Última edición por rgstuamigo fecha: 07-10-2010 a las 23:10:57.
Responder Con Cita
  #17  
Antiguo 08-10-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
La verdad creo que no me entienden o no me dejo entender, aca un demo de lo que deseo hacer pruebenlo y me dicen, pero falla, la grilla no queda con los datos exactos. El problema es que cuando me deslizo hacia abajo con el mouse los datos de la grilla se repiten con el registro anterior.

Código Delphi [-]
 
// Definicion Global desprotejer DBGrid
type
  TDBGrid = class(DBGrids.TDBGrid);

procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
var
  aRect : TRect;
begin
  // Init
  TDBGrid(Sender).Canvas.Font.Style := [];
  TDBGrid(Sender).Canvas.Font.Color := clWindowText;
  TDBGrid(Sender).Canvas.Brush.Color := clWindow;

  TDBGrid(Sender).Canvas.Brush.Color := $00EFD3C6;
  aRect := TDBGrid(Sender).CellRect(DataCol + 1, TDBGrid(Sender).Row);

  if (gdSelected in State) and
     (TDBGrid(Sender).Focused) then
  begin
    TDBGrid(Sender).Canvas.Font.Color := clWhite;
    TDBGrid(Sender).Canvas.Brush.Color := clHighlight;
  end;

  TDBGrid(Sender).DefaultDrawColumnCell(aRect, DataCol, Column, State);
end;

Última edición por RebeccaGL fecha: 08-10-2010 a las 00:58:13.
Responder Con Cita
  #18  
Antiguo 08-10-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

Cita:
Empezado por connor Ver Mensaje
La verdad creo que no me entienden o no me dejo entender, aca un demo de lo que deseo hacer pruebenlo y me dicen, pero falla, la grilla no queda con los datos exactos. El problema es que cuando me deslizo hacia abajo con el mouse los datos de la grilla se repiten con el registro anterior.
...
Creo entender tu problema , ese error puedes solucionarlo haciendo que el DBGrid se repinte por completo cada ves que deslizas o mueves con el mouse al DBGrid.
Para lograrlo puedes utilizar el evento OnDataChange del componente DataSource al que está enganchado tu DBGrid y poner un código como éste:
Código Delphi [-]
procedure TForm1.DataSource1DataChange(Sender: TObject; Field: TField);
begin
  DBGrid1.Invalidate;//<--hago que se repinte el DBGrid por completo
end;
Espero que con eso soluciones tu problema.
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7

Última edición por rgstuamigo fecha: 08-10-2010 a las 21:41:03.
Responder Con Cita
  #19  
Antiguo 10-10-2010
Avatar de RebeccaGL
RebeccaGL RebeccaGL is offline
Miembro
 
Registrado: ene 2008
Posts: 199
Poder: 17
RebeccaGL Va por buen camino
rgs gracias por responder, ya halle la solucion para este problema del dbgrid y lo hice de esta manera.


Código Delphi [-]
 
type
  THackDBGrid = class(TDBGrid);
...
 
procedure TForm_BeEMPPRJ.DBGrid_COMMOVDrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
begin
  DBGrid_COMMOV.Canvas.Font.Style := [];
  DBGrid_COMMOV.Canvas.Font.Color := clWindowText;
  DbGrid_COMMOV.Canvas.Brush.Color := clWindow;

  if (THackDBGrid(DBGrid_COMMOV).DataLink.ActiveRecord + 1 = THackDBGrid(DBGrid_COMMOV).Row) then
    DBGrid_COMMOV.Canvas.Brush.Color := $00EFD3C6;

  if (gdSelected in State) and
     (DBGrid_COMMOV.Focused) then
  begin
    DBGrid_COMMOV.Canvas.Font.Color := clWhite;
    DbGrid_COMMOV.Canvas.Brush.Color := clHighlight;
  end;

  DBGrid_COMMOV.DefaultDrawColumnCell(Rect, DataCol, Column, State);
end;


Ahora solo me quedan dos problemas, y creo que son los mas graves, unos es que antes de ejecutar mi programa en otra PC me sale el error

"cant find any matching row in the user table"

Y el otro error es que tengo tres tablas enlazadas

Tabla_AÑO >> Tabla_MES >> Tabla_DIA

Tabla_AÑO es la tabla padre Tabla_MES es la tabla hija y Tabla_DIA es hija de Tabla_MES

Cuando hago un Post en Tabla_AÑO se disparan por cualquier lado los registros de las tablas hijas Tabla_MES y Tabla_DIA, es decir, que si estoy en el año 01-01-2010 y hago un post la Tabla_AÑO los registros de las tablas hijas se mueven de "Enero a Octubre", o a cualquier dia del año, sin nigun motivo sin hacer scroll ni nada.

Estoy usando componentes ZeosLib creo que esos componentes estan con errores y se cruzan, bueno nose, pero esos son los problemas que ahora me preocupan mucho y no se como resolverlos.



Gracias, saludos.

Última edición por RebeccaGL fecha: 10-10-2010 a las 01:26:28.
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
Opiniones ZeosLib alquimista_gdl Conexión con bases de datos 20 15-03-2009 20:06:57
ZeosLIB cmm07 Varios 6 11-11-2008 01:34:35
zeoslib 6.6.2 rc geolife Noticias 17 17-08-2008 08:21:23
ZeosLib y MySQL 5 onlytk Conexión con bases de datos 2 31-12-2005 03:37:52


La franja horaria es GMT +2. Ahora son las 19:10:25.


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