![]() |
Ordenar datos en un DBGrid con click en cabecera
Bueno como vi que en la parte de trucos no funcionaba para componentes de dbExpress, le pregunte a google y me respondio XD.
Este código pertenece al siguiente sitio Código que realiza el ordenamiento:
Código para utilizar el ordenamiento:
Saludos |
Hola totote
si quieres ordenar por columna los datos que tienes un dBGrid, puedes utilizar el codigo que esta a continuación.. Debes utilizar el evento OnTitleClick del DBGrid...si pincho 1 vez me ordena por la columna en forma ascendente y si lo vuelvo a presionar me lo ordena en forma descendente... para controlar ese evento utilizo una variable ( Sw_1)
bueno, el codigo anterior te ordena solo si pinchas en la columna con el titulo RUT, por lo que deberas agregar las demas columnas que necesites ordenar... Espero que te funcione.. Salu2:p:D |
Pero el código que pone totote está pensado específicamente para un ClientDataSet lo cual da la enorme ventaja de no tener que reconsultar a la base. El ordenamiento se hace en memoria, por lo cual es mucho más rápido. Además, el código es genérico; sirve para cualquier ClientDataSet sin importar el nombre de los campos ni la columna seleccionada.
Eso sí, creo que se puede simplificar un poco :p
// Saludos |
Bien roman quedó bastante simplificado, igualmente yo lo postee así porque así lo encontre
Saludos |
Cita:
Interesante el código.. esto me simplificaria varias lineas... ahora donde se debe dejar este código y como se vincula a un dbGrid....??? para cuando pinchen los titulos se ordene.... Salu2:p:D |
|
Cita:
// Saludos |
Cita:
Ok...gracias... lo estoy probando..aunque no con muy buenos resultados... pero seguiré intentando.. Salu2:p:D |
El Código simplificado de Roman no lo pude probar, pero el código original el único error que le encontre fue que una vez utilizado el código, se desvincula el DBGrid y queda abierto el ClientDataSet, al volver a vincular el DBGrid me genera erro al querer encontrar las columnas con la cabezera modificada, despúes a mi me anduvo sin ningún problema.
Saludos :D |
Cita:
Cita:
// Saludos |
No, no quise decir que no sirve sino que no lo he probado para ver como funciona realmete, para saber si anda o no hay que utilizarlo.
Saludos |
me da error
Bueno.,... segui con las pruebas....
lo que hice fue crear una unidad nueva, pero me da error.... con el código que puso Roman cree esta unidad
pero me da el error de compilación Unit17.pas(8): Undeclared identifier: 'TColumn' Unit17.pas(18): Then expected but identifier 'FieldName' found bueno y da otros más... quizas puede ser por que faltan algunas uses.... Salu2:p:D |
Tambien probe con el codigo que dejo Totote.... si bien la funcion no me da error, cuando quiero ejecutar el codigo si me da error, pero puede ser por algo que este realizando mal...
bueno, del codigo anterior, no se muy bien que debe ir en ClientDataSet1, puesto que lo he cambiado por el DBGrid, DataSourse y ADOQuery sin tener resultados positivos... Salu2:p:D |
Cita:
Supongo que te falta DBGrids y te sobra TypInfo. // Saludos |
Hola Roman
gracias... ya agrege/quite la unidad que me indicastes.... se compila, ya no da error... estoy con el problema de poder utilizarla.... Segun como me indicastes, puse lo siguiente....
pero me da error de incompatibilidad de tipos (TClientDataSet and TADOQuery / TClientDataSet and TDataSource / TClientDataSet and TDBGrid ) Bueno.. eso.. Salu2:p:D |
Pero amigo Blue, estamos en distinto canal :D
Me cito a mi mismo Cita:
// Saludos |
Bueno con respecto al Código original cuando se quería abrir el TClientDataSet generaba un error que no reconocia la columna, para solucionar ese problema lo que hice fue que al salir del formulario antes de cerrar el TClientDataSet llamo al siguiente procedimiento:
que sería esto solamente:
Saludos. |
El siguinte codigo ordena con click en cualquier columna, pero necesito saber como se que una columna esta ordenada ASC o DESC para luego reordenarla.
PD: ABSQuery = Query |
Bueno esto es lo que yo uso para ordenar en un DBGrid utilizando ClientDataSets.
Esto es gracias a que el ClietDataSet permite crear índices en memoria en tiempo de ejecucíon (Sin crearlos en la base de datos, claro). Espero que a alguien le sirva. |
Muchas gracias por tu aporte jorge82. Lo probé y me ha funcionado perfectamente!
Gracias de vuelta! |
La franja horaria es GMT +2. Ahora son las 23:30:07. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi