Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   OOP (https://www.clubdelphi.com/foros/forumdisplay.php?f=5)
-   -   Duda Puntual: Ventana de Busqueda Catálogos Grandes. (https://www.clubdelphi.com/foros/showthread.php?t=45023)

Paoti 20-06-2007 21:21:38

Duda Puntual: Ventana de Busqueda Catálogos Grandes.
 
¡Hola!, Yo aquí de nuevo.

Tengo una super duda, funcional, a nivel OOP.


Espero ser explicito. (Paoti ordenando ideas :eek: raro.)

Tengo un cátalogo de muchos datos.
Ejemplo. Enfermedades (10,000 registros)

En la tabla donde se va a guardar el ID_enfermedad, es la tabla de Pacientes.

Ahora en un formulario.

La idea:

Una caja de texto: donde se capturará el id_enfermedad.
Una etiqueta: Donde aparecerá la descripción de la enfermedad.

Ahora, en caso de que se capture el id_enfermedad en la caja de texto, y exista en el catálogo, autimaticamente aparece la descripción en la etiqueta.

En caso contrario, sino se encuentra la clave, sea porque no se escribio nada o porque lo que se escribio se encontraron varias coincidencias en la base de datos, aparezca una ventana de busqueda, la cual, aparecera un grid y una caja de texto o dos, que harán una busqueda incremental sobre el catalogo de Enfermedades, una vez seleccionada la enferdad, esta se agregue en la cja de texto y etiqueta del formulario de captura.


La duda que no sé como diseñarla, es la siguiente.

como crear esa ventana de busqueda (Grid y Cajats de texto) pasandole la consulta o dataset, y despues de obtener el registro deseado, devolverlo al formulario de captura.



Gracias por el apoyo comunidad. mil gracias.


Paoti Rios
Monterrey. N.L.
México

ContraVeneno 20-06-2007 23:09:03

Código Delphi [-]
En el botón o evento de búsqueda:

with TuConsulta do begin
   if active then close;
   SQL.Clear;
   SQL.Add('Select ID, Descripcion');
   SQL.Add('From TuTabla');
   SQL.Add('where ID like :vID');
   SQL.Add('Order By ID');
   ParamByName('vID').AsString := edtEnfermedad.Text +'%';
   Open;
    case RecordCount of
    0:
     begin
      messagebox('no existe');
     end; //case 0
    1:
     begin
      edtEnfermedad.Text:=FieldByName('ID').AsString;
      edtDescripcion.Text := FieldByName('Descripcion').AsString;
     end; //case 1
    else
     begin
       DM.qryBuscar.SQL:=SQL;
       DM.qryBuscar.Open;
      //Generar la ventana de búsqueda si existen elementos
      //if not(Assigned(frmBuscar)) then begin
       frmBuscar:=TfrmBuscar.create(Application);
       OpcionBusqueda:=3;
       frmBuscar.ShowModal;
      //end;
      if Seleccionado then begin
       edtEnfermedad.Text:=FieldByName('ID').AsString;
       edtDescripcion.Text := FieldByName('Descripcion').AsString;
      end else begin
       Close;
      end; //if
     end; //case else
    end; //case
   end; //with

Aquí estoy tomando un formulario que se llama "frmBuscar", el cuál contiene un DBGrid asociado a un TQuery que se llama "qryBuscar". Al seleccionar un registro en este formulario, hago lo siguiente, dependiendo de la opción de búsqueda:

Código Delphi [-]
 case OpcionBusqueda of 
  3: begin
      with TuConsulta do begin
        if active then close;
        SQL.Clear;
        SQL.Add('Select ID, Descripcion');
        SQL.Add('From TuTabla');
        SQL.Add('where ID = :vID');
        SQL.Add('Order By ID');
        ParamByName('vID').AsString := DM.qryBuscar.Fields[0].AsString;
       Open;
      end; //with
    end; //case 3
  Seleccionado := True;

Paoti 20-06-2007 23:32:44

Gracias contraveneno, voya realizar eso esta semana, cualqueir duda, más que anda en la comunciación entre los dos formularios, probablemente, me doy una vuelta por aquí.


mil gracias.


La franja horaria es GMT +2. Ahora son las 21:42:57.

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