Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 06-11-2004
Avatar de RONPABLO
[RONPABLO] RONPABLO is offline
Miembro Premium
 
Registrado: oct 2004
Posts: 1.514
Poder: 21
RONPABLO Va por buen camino
Primera fila visible de un grid

Un Saludo a todos...

Al ver por medio de un dbgrid un dataset necesito cambiar la informacion de un registro cualquiera, volver a realizar el Query y localizar nuevamente la posicion del registro. todo esto lo hago pero tengo una pequeña molestia y es que el locate funciona desde el primer registro hasta el ultimo y asi al localisar esté queda en la mayoria de las ocaciones en la ultima y en ocaciones en la primer fila visible y yo necesito que esta fila quede justo donde se realizo el click. algo asi como esto

Antes de editar_|Como me esta quedando normalmente_|como quiero que quede
I 6 I__________|____ I 4 I ___________ I 7 I Dato Fin_ | ___ I 6 I
I 7 I Dato Ini___|____ I 5 I ___________ I 8 I ________ | ___ I 7 I Dato Fin
I 8 I__________|____ I 6 I ___________ I 9 I ________ | ___ I 8 I
I 9 I__________|____ I 7 I Dato Fin____ I10I ________ | ___ I 9 I

Cordial Saludo
Responder Con Cita
  #2  
Antiguo 06-11-2004
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Ordena la consulta por un campo que NO VA A CAMBIAR, y despues establece TopRow

Cita:
Read TopRow to determine the index of the first row in the scrollable region that is visible. Set TopRow to scroll the rows in the grid so that the row with index TopRow is the first row after the fixed rows.
Responder Con Cita
  #3  
Antiguo 06-11-2004
Avatar de RONPABLO
[RONPABLO] RONPABLO is offline
Miembro Premium
 
Registrado: oct 2004
Posts: 1.514
Poder: 21
RONPABLO Va por buen camino
TopRow??

Cita:
Empezado por Lepe
Ordena la consulta por un campo que NO VA A CAMBIAR, y despues establece TopRow
Yo tengo delphi 6 y pues no encuentro esta propiedad para un DBGrid, la encuentro en un stringGrid o en un DrawGrid, talvez estoy haciendo algo mal como tal lo que pongo es:

y:= DBGAgenda.TopRow; // DBGAgenda es el nombre delDBGrid que uso
Responder Con Cita
  #4  
Antiguo 06-11-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
No sé si será algo como esto lo que quieres?
Código Delphi [-]
  procedure TForm1.Button1Click(Sender: TObject);
  Var
  Y:Integer;
  begin
  y:=TStringGrid(DbGrid1).Row;
  ShowMessage(IntToStr(y));//quitar esto.
  TStringGrid(DbGrid1).TopRow:=y;
  end;
Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #5  
Antiguo 06-11-2004
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
Y ¿por qué debes hacer nuevamente la consulta? ¿No sirve poner la propiedad RequestLive del Query en true?

Por cierto Marcos, no quiero ponerme pesado pero te recuerdo el hilo problemas la hacer un cast de un TStringGrid(DBGrid).

// Saludos
Responder Con Cita
  #6  
Antiguo 07-11-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Román cuando contesté a este hilo, sabía que me ibas a responder de esta manera, y tienes razón.

La respuesta viene enfocada de la siguiente forma, algo sencillo y que funcione y resuelva el problema, teniendo en cuenta que esto sería un resultado final, nadie va a derivar nada más de este código, solamente lo va a mantener quien lo hizo.

Ahora bien, lo que tu apuntas, de acuerdo, es una auténtica aberración moldear un objeto con un molde de otro del cual no desciende.

Conclusión final, si quieres que además de que funcione siga una ortodoxia y no utilizar este "truco sucio", debes de hacer lo que dice Román.

Mi solución aunque funciona, en un examen, tendría un 0.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.

Última edición por marcoszorrilla fecha: 07-11-2004 a las 12:20:10.
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 13:46:53.


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