27-04-2005
|
Miembro
|
|
Registrado: nov 2004
Ubicación: mvd, uruguay
Posts: 57
Reputación: 20
|
|
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
|