![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
Saludos amigos.
Atención Rochi, visita este link http://delphi.about.com/od/usedbvcl/l/aa050499.htm y encontrará un ejemplo claro y sencillo de lo que necesitas. Espero le ayudes a todos los que necesitan realizar busqueda incremental. Nelson Polanco Rep. Dom. |
|
#2
|
|||
|
|||
|
Lepe.
Saludos, a todos. Hice lo que me dice pero se produce un error en le linea de codigo del DBEdit. Autocompleta(DBEdit1, Query1, 'Nombre'); [Error] Unit5.pas(78): Undeclared identifier: 'Autocompleta' El Autocompleta se consigue con los codigos que publicate mas arriba? Puede explicarme como manejo estos codigos para que me funcionen, para una Tabla paradox de nombre TableDueño en el campo Dueño. Gracias, por toda su colaboración. Última edición por gregorio fecha: 26-04-2005 a las 23:49:10. |
|
#3
|
|||
|
|||
|
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;
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 |
|
#4
|
||||
|
||||
|
Cita:
File -->new Unit, y añade las el código publicado aqui, cada uno en su sección correcta, Interface e implementation. Guarda la unidad como UCompleta.pas. Donde desees usarlo, tienes que añadir el "uses" para decirle a delphi donde está la rutina; para ello, ve a la linea :
Veo que en tus campos y tablas utilizas la letra 'ñ' delphi no va a reconocer ese carácter, así que cambia el nombre de la tabla y campo por : Tabladueno, Dueno. No necesitas hacer un query.last, simplemente llamar a esa rutina. Un saludo
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
|