FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Ordenar un DBGrid por columna
Hola a todos, he visto en internet y en este foro tambien como ordenan un DBGrid al hacer click en el titulo de la columna
y despues en el evento title click del DBGrid El esunto es que trabajo con Delphi 7, Paradox, Ttable y datasource, no con ADO, no se si se puede adaptar el codigo o le puedo agregar ADOtable? Tambien encontre este codigo para reemplazar el anterior con la opcion de reemplazar IndexFieldNames por IndexName, pero me tira un error "Index does not exist..." se ve que debo crear el indice de las columnas o las tablas, como se realiza esto? si alguien me puede ayudar le agradecere, de ultima si no se puede hacer esto en la columna, lo haria en un boton, como Que tampoco funciono Última edición por Casimiro Notevi fecha: 25-11-2012 a las 19:26:49. |
#2
|
||||
|
||||
Hola
La verdad no entiendo la pregunta. Saludos
__________________
Siempre Novato |
#3
|
|||
|
|||
Hola Caral,
lo que quiero hacer es ordenar las columnas del DBRgrid que por defecto esta ordenado por el ID, se pueda ordenar por lo que el usuario necesite. Supongamos que en el DBGrid muestra ID, nombre, apellido, ciudad. el usuario al hacer click en el encabezado de la columna, pueda ver ordenado a travez de apellido o de ciudad o de nombre, y si es con un boton, podria ser con la ayuda de un checkbuton en donde tenga la posibilidad de elegir ID, apellido, nombre y ciudad y al apretar el boton se ordene por la seleccion correspondiente. En lo personal, me gustaria la primer opcion, de hacer click en el titulo de la columna y se ordene por este. Espero que haber sido mas claro ahora, Saludos. |
#4
|
||||
|
||||
Hola
Se podria hacer muy facilmente con un combobox, no? Saludos
__________________
Siempre Novato |
#5
|
||||
|
||||
De todas formas, de una o de otra forma, lo que no se entiende es el problema que tienes.
|
#6
|
|||
|
|||
el problema es que no se como hacerlo, como mencione me gustaria poder hacer click en el titulo de la columna y que se ordene por este, pero la codificacion que encontre trabaja con ADO.
se puede modificar esa codificacion para que funcione con Ttable y datasource? Saludos |
#7
|
||||
|
||||
Hola
Todo se puede hacer amigo. El asunto es: 1- Tiene que ser especificamente een el titulo del dbgrid (me parece que el cliente tendra que imaginar que es ahi, no lo veo muy logico) 2- Puede ser como dije antes en un combobox que indique la opcion de filtrado ? (me parece mas claro). Saludos
__________________
Siempre Novato |
#8
|
|||
|
|||
Si tienes razon, a veces cuesta pensar que el cliente no tiene la mas minima idea de como funciona cada cosa y aunque pueda parecer mas simple hacer click en el titulo para ordenar cada columna, el cliente no se lo puede imaginar que hace eso.
Y como seria en un combobox, necesitaria un boton en donde codificar que lo ordene por cada eleccion, yo habia hecho esto y no funciono, pero talvez es algo parecido, no?
Última edición por Casimiro Notevi fecha: 26-11-2012 a las 11:11:23. |
#9
|
||||
|
||||
Hola
No se por que pones un ejemplo con query y antes estabas pidiendo alguna opcion con tqble , no entiendo. Bueno: El concepto es simple: Colocas un combobox con las opciones de filtrado (id, cliente, etc...). En el evento onchange del combobox pones o haces el filtro en el caso de un table o la sentencia sql en el caso del query Seria bueno saber con que lo vas a hacer para tratar de darte un ejemplo mas concreto. Saludos
__________________
Siempre Novato |
#10
|
|||
|
|||
Lo hare con lo que crean que es mejor y mas sencillo.
|
#11
|
||||
|
||||
Que tal esto:
Un saludo
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber. |
#12
|
|||
|
|||
Gracias olbeup
nunca use unTCustomADODataSet Lo relaciono con el DataSource y algo mas? ya que me tira error cuando lo ejecuto al hacer click en el encabezado. |
#13
|
||||
|
||||
Amigo DOS, no tienes tiempo de leer un libro para aprender sobre lo que estás trabajando y además sigues poniendo comentarios inservibles, veamos:
Pregunta que cae por su propio peso: me tira error, ¿qué error? |
#14
|
|||
|
|||
Este error 'access viloation at 0x0012fdf6: read of address 0x00000000'. Process Stopped...
supongo que no sera problema del TCustomADODataSet ya que no mencionaste que estuviera mal conectado, asi que no se que significa ese error. obiamente algo no realice bien. |
#15
|
|||
|
|||
Bueno ya lo solucione, lo hice como aconsejaba caral, con un combobox, lo que no sabia era que tenia que definir a los campos como clave secundaria para que los pueda ordenar. Gracias.
|
#16
|
||||
|
||||
Hola DOS,
Creo que estas en un error, si en tú DBGrid, presentas de 8 a 10 campos o más, esos 8 ó 10 campos o más tienen que estar indexados, E R R O R , en un DBGrid puedes ordenar por cualquier campo pulsando en el título, A C I E R T O, si te ha dado ese error es por el TCustomADODataSet, no lo estas haciendo bien. Un saludo.
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber. |
#17
|
||||
|
||||
Yo lo que hago es el proceso siguiente:
Donde Sw_1 es una variable Integer y privada del form, lo tengo combinado con un ComboBox para poder hacer la selección desde ambos componentes. Nota: Utilizo firebird 1.5. Saludos Josep |
#18
|
|||
|
|||
Cita:
jafera, lo voy a probar Gracias, saludos. |
#19
|
||||
|
||||
Cita:
TCustomADODataSet es la clase base de los componentes de datos ADO y no se usa directamente. olbeup realiza el moldeado con el ancestro común de TADOQuery y TADOTable para que la propiedad Sort pueda ser utilizada sea cual fuere al que el DBGRid este relacionado. Tratándose de BDE, podrías usar un TQuery:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 27-11-2012 a las 21:02:58. |
#20
|
|||
|
|||
Gracias ecfisa, recien hoy pude ponerme a trabajar, el asunto es que lo voy a realizar con un Query y dataSource por medio del combobox, el codigo que realice es el siguiente.
El asunto es que lo que hace es poner los campos de arriba para abajo o de abajo para arriba, pero no los ordena alfabeticamente, solo gira las tablas. Faltará configurar algun dato en elgun lado? Gracias por su ayuda. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Ordenar STringGrid por más de una columna | dandia28 | OOP | 3 | 05-07-2011 05:37:37 |
Ordenar un DBGrid por una columna por defecto | JM75 | OOP | 2 | 04-05-2007 12:46:53 |
Ordenar TStoreProc al clickear columna en DBGrid | Mauro.NET | Varios | 0 | 04-05-2006 17:28:18 |
Ordenar Listview por columna | Coco_jac | Varios | 10 | 03-01-2006 19:03:20 |
Como ordenar un dbgrid segun la columna seleccionada | pyanqn | Varios | 1 | 08-11-2005 15:59:41 |
|