Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-06-2013
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Post 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:
Código Delphi [-]
void __fastcall TForm5::Edit2Change(TObject *Sender)
{

        Table1->Filtered = false;
        Table1->Filter = "Detalle =" + QuotedStr(Edit2->Text+"*");
        Table1->Filtered = true;
}
//---------------------------------------------------------------------------


void __fastcall TForm5::Edit3Change(TObject *Sender)
{
             
Table1->Filtered = false;
  Table1->Filter = "Marca =" + QuotedStr(Edit3->Text+"*");
        Table1->Filtered = true;
}
//---------------------------------------------------------------------------


void __fastcall TForm5::Edit2Click(TObject *Sender)
{
   Edit3->Text=EmptyStr;
   Table1->Filtered=false;
}
//---------------------------------------------------------------------------

void __fastcall TForm5::Edit3Click(TObject *Sender)
{
      Edit2->Text=EmptyStr;
      Table1->Filtered=false;  
}

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.
Responder Con Cita
  #2  
Antiguo 27-06-2013
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por giulichajari Ver Mensaje
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.
Hola.

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;
}
El punto 3 es el que mas se complica por culpa del punto 2 ya que, estando en un Edit, vas a tener que llamar al form que tiene el TQuickRep sin que se pierda el foco (y por tanto el filtro).

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)
}
Por otro lado, en Form2 tendras que agregar al QuickRep un TQRSubDetail con su propiedad DataSet = Form1->Table1. Y tantos TQRDBText como campos se muestren en las columnas de Form1->DBGRid, todos con su propiedad DataSet = Form1->Table1 y cada uno con su nombre de campo correspondiente.

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]
Responder Con Cita
  #3  
Antiguo 29-06-2013
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
¿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
Responder Con Cita
  #4  
Antiguo 30-06-2013
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola giulichajari.
Cita:
Empezado por giulichajari Ver Mensaje
...
Y al salir del Edit deja de estar filtrada la tabla,ya que quiero poner en form1 2 botones, uno que imprima todo, y el otro solo lo filtrado...
Si, es lo que te comentaba en el mensaje anterior.

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;
}
es decir que podras usar los TButtons para llamar a la impresión.

Cita:
...No se si poner 2 TTable o con la misma alcanza...
No es necesario usar otro TDataset, podes hacerlo con el mismo.
Cita:
He creado dos QuicReport en dos Form distinto para cada impresion respectivamente.Tal vez con un solo Report es suficiente.
Por lo que comentas pareciera que con un solo botón para imprimir y un solo TQuickRep tendría que alcanzar. Si el TDataSet está sin filtro se imprimirán todos los registros, si tiene alguno sólo los registros filtrados.

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #5  
Antiguo 30-06-2013
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Continuando

Código Delphi [-]
{
  String sFilter;
  TEdit *ed = static_cast  (ActiveControl);

  if (ed->Name == "Edit2")
    Edit3->Text = "";
  else
    Edit2->Text = "";
  Table1->Filtered = false;
}

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:

Código Delphi [-]
void __fastcall TForm5::Edit2Change(TObject *Sender)
{
     String sFilter = "";
  TEdit *ed = static_cast  (ActiveControl);

  if (ed->Name == "Edit2" && !ed->Text.IsEmpty()) {
    Edit3->Text = "";
    sFilter = "Marca = " + QuotedStr(Edit2->Text + "*");
  }
  if (ed->Name == "Edit3" && !ed->Text.IsEmpty()) {
    Edit2->Text = "";
    sFilter = "Detalle = " + QuotedStr(Edit3->Text + "*");
  }
  Table1->Filtered = false;
  Table1->Filter   = sFilter;
  Table1->Filtered = true;
}
//---------------------------------------------------------------------------

void __fastcall TForm5::Edit3Change(TObject *Sender)
{
         String sFilter = "";
  TEdit *ed = static_cast  (ActiveControl);

  if (ed->Name == "Edit2" && !ed->Text.IsEmpty()) {
    Edit3->Text = "";
    sFilter = "Marca = " + QuotedStr(Edit2->Text + "*");
  }
  if (ed->Name == "Edit3" && !ed->Text.IsEmpty()) {
    Edit2->Text = "";
    sFilter = "Detalle = " + QuotedStr(Edit3->Text + "*");
  }
  Table1->Filtered = false;
  Table1->Filter   = sFilter;
  Table1->Filtered = true;
}
//---------------------------------------------------------------------------




void __fastcall TForm5::Button1Click(TObject *Sender)
{
Form6->QuickRep1->Preview();
}
//---------------------------------------------------------------------------



void __fastcall TForm5::FormKeyDown(TObject *Sender, WORD &Key,
      TShiftState Shift)
{
       if (Key == VK_F1)
    Form7->ShowModal();
}
//---------------------------------------------------------------------------

void __fastcall TForm5::FormCreate(TObject *Sender)
{
   KeyPreview = true;
}
//---------------------------------------------------------------------------

void __fastcall TForm5::Button1Enter(TObject *Sender)
{
   String sFilter;
  TEdit *ed = static_cast  (ActiveControl);

  if (ed->Name == "Edit2")

    Edit3->Text = "";
  else
    Edit2->Text = "";

  Table1->Filtered = true;
}
//---------------------------------------------------------------------------

void __fastcall TForm5::Button2Enter(TObject *Sender)
{
     String sFilter;
  TEdit *ed = static_cast  (ActiveControl);

  if (ed->Name == "Edit2")
    Edit3->Text = "";

  else
    Edit2->Text = "";
  Table1->Filtered = true;
}
Responder Con Cita
  #6  
Antiguo 30-06-2013
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
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
Archivos Adjuntos
Tipo de Archivo: zip giulichajari.zip (7,9 KB, 3 visitas)
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #7  
Antiguo 30-06-2013
giulichajari giulichajari is offline
Miembro
 
Registrado: nov 2012
Posts: 306
Poder: 12
giulichajari Va por buen camino
Muchas gracias

Gracias por todo..
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
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


La franja horaria es GMT +2. Ahora son las 13:36:59.


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