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.