FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Ayuda Busqueda en DBGrid con 2 campos
Hola de vuelta
Bueno tengo un Formulario con un DBGrid, 2 Edit correspondiente a 2 campos de la base de datos, para filtrar los datos del DBGrid. Pero necesito ayuda en lo siguiente 1-Que al borrar una letra en un Edit, se actualize la busqueda, es decir el DBGrid 2-Que al salir de un Edit se borre el otro y el dbgrid vuelva a sin estar filtrado. 3-Exportar el DBGRid filtrado para imprimir. El codigo que hice fue el siguiente:
Al cambiar OnChange, que actualize el DBGrid. Y al hacer click, que vacie el otro edit, y que el filtro vuelva a 0. Pero no funciona. Y el como exportar los resultados para imprimir no se, osea se usar quickreport pero no se como exportar el dbgfrid. |
#2
|
||||
|
||||
Cita:
El punto 1 ya lo tenes solucionado. Con el 2, podrías asignar este evento a los dos Edits: Código:
void __fastcall TForm1::EditExit(TObject *Sender) { Table1->Filtered = false; } Una posible solución es poner la propiedad KeyPreview del form a true y detectar una tecla, o combinación de ellas, en el evento OnKeyDown del mismo, algo parecido a: Código:
void __fastcall TForm1::FormCreate(TObject *Sender) { KeyPreview = true; } ... void __fastcall TForm1::FormKeyDown(TObject *Sender, WORD &Key, TShiftState Shift) { if (Key == VK_F1) Form2->ShowModal(); // (Form2 donde esta TQuickRep) } Para lo cuál Form2 deberá tener acceso a Table1 ya sea que esta resida en un TDataModule (la mejor opción) o mediante la inclusión de Form1, haciendo de este modo una referencia circular. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 27-06-2013 a las 18:51:00. Razón: Corregir etiqueta [I] [/I] |
#3
|
|||
|
|||
¿Y si tengo otra impresion?
Hola Eficsa, gracias por responder a mis temas.
Tengo un problema con lo que me dijiste que haga, ya que quiero poner en form1 2 botones, uno que imprima todo, y el otro solo lo filtrado. No se si poner 2 TTable o con la misma alcanza. Y al salir del Edit deja de estar filtrada la tabla, lo cual creo que tambien este dando problemas. Tengo un DataModule en el Form1, y los dos button. He creado dos QuicReport en dos Form distinto para cada impresion respectivamente. Tal vez con un solo Report es suficiente. Muchas gracias |
#4
|
||||
|
||||
Hola giulichajari.
Cita:
Pero se me ocurrió este modo que te permite darle el foco a cualquier componente (que no sea alguno de los dos edits en cuestión) sin que se pierda el filtro actual: Código:
/* Asignar al evento OnEnter de ambos edits */ void __fastcall TForm1::EditEnter(TObject *Sender) { String sFilter; TEdit *ed = static_cast <TEdit*> (ActiveControl); if (ed->Name == "Edit2") Edit3->Text = ""; else Edit2->Text = ""; Table1->Filtered = false; } /* Asignar al evento OnChange de ambos edits */ void __fastcall TForm1::EditChange(TObject *Sender) { String sFilter = ""; TEdit *ed = static_cast <TEdit*> (ActiveControl); if (ed->Name == "Edit2" && !ed->Text.IsEmpty()) { Edit3->Text = ""; sFilter = "Name = " + QuotedStr(Edit2->Text + "*"); } if (ed->Name == "Edit3" && !Edit3->Text.IsEmpty()) { Edit2->Text = ""; sFilter = "Capital = " + QuotedStr(Edit3->Text + "*"); } Table1->Filtered = false; Table1->Filter = sFilter; Table1->Filtered = true; } Cita:
Cita:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#5
|
|||
|
|||
Continuando
Porque pones el filtrado de la tabla en false, no me funciono, y al cvambiar esa linea a true me anduvo para un solo Edit, para el Edit3. Este es el codigo del cpp del form en el que trabajo:
|
#6
|
||||
|
||||
Hola.
Creo que estas mezclando el modo del mensaje #2 con el que te sugerí después (msg #4). Para evitar confusiones te armé un pequeño ejemplo que consta de un Form principal, un DataModule, otro form para visualizar el QuickRep, así podrás estudiarlo con tranquilidad. Solo tenes que crear una carpeta y descomprimir el archivo ahí (incluye tabla de BCDEMOS). Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#7
|
|||
|
|||
Muchas gracias
Gracias por todo..
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Ayuda reflejar datos en DBgrid y Campo busqueda | avila | Varios | 3 | 20-07-2011 16:12:51 |
Problema campos de busqueda | Luis Castillo | Firebird e Interbase | 7 | 06-01-2006 16:55:23 |
Problemas con los campos Busqueda | walace_soy | Firebird e Interbase | 5 | 24-09-2004 09:02:15 |
campos de busqueda................. | David J. | Conexión con bases de datos | 3 | 06-07-2004 17:34:36 |
Busqueda por 2 campos a la vez | CJRE | SQL | 3 | 26-05-2004 18:48:36 |
|