Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-04-2005
Nelson Polanco Nelson Polanco is offline
Miembro
 
Registrado: abr 2005
Ubicación: Provincia Espaillat, Rep. Dom.
Posts: 15
Poder: 0
Nelson Polanco Va por buen camino
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.
Responder Con Cita
  #2  
Antiguo 26-04-2005
gregorio gregorio is offline
Registrado
 
Registrado: abr 2005
Posts: 4
Poder: 0
gregorio Va por buen camino
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.
Responder Con Cita
  #3  
Antiguo 27-04-2005
rochi rochi is offline
Miembro
 
Registrado: nov 2004
Ubicación: mvd, uruguay
Posts: 57
Poder: 22
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
  #4  
Antiguo 28-04-2005
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 31
Lepe Va por buen camino
Cita:
Empezado por gregorio

[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.
Todo el código de Autocompleta, supongo que lo has pegado en una unidad nueva.

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 :

Código Delphi [-]
Unit NecesitoElAutocompletaEnEstaUnidad;

uses Forms, controls, Windows, ... UCompleta;

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.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 19:57:02.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi