Ver Mensaje Individual
  #18  
Antiguo 27-04-2005
rochi rochi is offline
Miembro
 
Registrado: nov 2004
Ubicación: mvd, uruguay
Posts: 57
Reputación: 20
rochi Va por buen camino
Hola, Nelson gracias por el link, de ahí saqué algunas ideas cuando andaba buscando ayuda sobre el tema. Lo mío tiene algunos cambios, para comenzar uso TClientDataSets anidados, ya que así manejo una relación maestro-detalle (recordar que estoy con FB + d7 + IBX).

Lo que hice, y al menos funciona, fue lo siguiente: en un ComboBox, tengo los parámetros de búsqueda, que son los campos de la tabla en cuestión.Y tengo en un box de edición edSearch, que es donde se almacena lo que se va digitando.
Código:
 ´
// en el evento OnChange de edSearch 
//dmSocios -> datamodule con los componentes del Socio. El datamodule se crea al abrir el form del Socio.

if Length(edSearch.Text) > 0 then
  begin
	  if self.ComboBox.ItemIndex >= 0 then
		 begin
			if (not dmSocios.EjecQry(ComboBox.text,Trim(edSearch.Text))) then
			   Application.MessageBox('No se
encontraton resultados','¡Atención!',MB_OK)
		 end
  else
	 Application.MessageBox('No seleccionó criterio de	 búsqueda','¡Atención!',MB_OK)
  end;
//Aqui ejecuto la SQL en el CommandText 

function TdmSocios.EjecQry(param:String;text_buscar:String):Boolean;
begin
	cdsSocios.close;
	cdsSocios.CommandText := 'Select * from SOCIOS where ' + 'Upper( '+ param + ') Like ' + QuotedStr(UpperCase(Text_buscar) + '%');
	cdsSocios.Open;
 
	Result := cdsSocios.RecordCount <> 0
end;
El resultado se despliega en una grilla que tiene asociado el DataSource del cdsSocios.

Claro, esto es para búsquedas con campos que son strings, pero con un campo numérico, no cambia demasiado la idea tampoco. Si tienen idea de como unficar todo en una consulta,...ya que si ingreso un entero, se despliega ese valor, y no un conjunto de valores. No hay búsqueda incremental en ese caso, a menos que trate al valor como un string.

En fin, si creen que estoy complicandome o haciendo las cosas poco elegantemente, serán bienvenidas y agradecidas todas las sugerencias.
Saludos, rochi

Responder Con Cita