Ver Mensaje Individual
  #2  
Antiguo 02-03-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Reputación: 28
jachguate Va por buen camino
Cool

hay mil formas de hacerlo. El query no es descabellado, pues podes generar la clausula where en tiempo de ejecución, incluso para mezclar varios criterios de busqueda, digamos los de nombre Pedro cuyo representante contenga Juan...

Para que un query sea actualizable, basicamente debe extraer sus datos de una sola tabla (o de una vista que a su vez cumpla con este mismo criterio), no usar funciones agregadas (sin group by) y no tener campos calculados. En delphi simplemente pones RequestLive a True.

También podes aplicar un flitro local, aunque con muchos registros será ineficiente. Si usas BDE el filtro igual podes construirlo y ponerlo en la propiedad Filter del TBDEDataSet en cuestión, y poner filtered a true. También podes usar el evento OnFilterRecord (lo hará mas lento todavia, pero podes tener filtros mas complejos) y podes discriminar según el criterio elegido por el usuario haciendo algo como:

Código:
begin
  if rgCriterio.ItemIndex = idxPorNombre Then
    Accept := Pos(NombreABuscar, Nombre) > 0
  else if rgCriterio.ItemIndex = idxPorApellido Then
    Accept := Pos(ApellidoABuscar, Apellido) > 0
  else 
    CualquierOtroCriterio;
end;
Por último, podes valerte de la propiedad ReadOnly de los campos del dataset para conseguir que unos sean actualizables y los otros no.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita