Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 12-08-2012
n03l n03l is offline
Miembro
 
Registrado: feb 2007
Posts: 73
Poder: 18
n03l Va por buen camino
Busqueda Booleana con IBDataset

saludos, acudo a uds a ver si me echan una manita en lo siguiente:

Tengo que hacer una busqueda en una tabla (Firebird y IBDataset):

esto es lo que estoy haciendo:
cuando abro el IBDataset solo llamo los ultimos 100 registros insertados en tabla
Código Delphi [-]
SelectSQL.Text:='select First 100 * from clientes ORDER by c DESC';

el problema que tengo esque necesito crear una condicion de busqueda en esta tabla pero que busque en todos los datos de la tabla y no nada mas en los 100

tengo este codigo con el cual hago busquedas y funciona bien
Código Delphi [-]
with IBDataset do
  begin
    Close;
    SelectSQL.Text:='SELECT * FROM CLIENTES WHERE NOMBRE LIKE :VALUE';
    ParamByName('VALUE').Value:= Edit1.Text + '%';
    Open;
  end;
pero yo quisiera buscar con el condicional if
Código Delphi [-]
if encuentro_cliente then
ShowMessage('Encontrado')
else
ShowMessage('No_Existe')

Cual seria la manera mas eficiente para hacer la busqueda Booleana en este caso?

saludos....
Responder Con Cita
  #2  
Antiguo 12-08-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola.

Podrías valerte del método IsEmpty, por ejemplo:
Código Delphi [-]
function ClienteExiste(aDataSet: TIBDataSet; aName: string):Boolean;
begin
  with aDataSet do
  begin
    Close;
    SelectSQL.Text:='SELECT * FROM CLIENTES WHERE NOMBRE LIKE :VALUE';
    ParamByName('VALUE').Value:= aName;
    Open;
    Result:= not IsEmpty;
  end;
end;

Llamada ejemplo:
Código Delphi [-]
...
  if ClienteExiste(IBDataSet,Edit1.Text) then
    ShowMessage('existe')
  else
    ShowMessage('no existe')
...

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #3  
Antiguo 13-08-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Al usar First 100 no le estás diciendo que traiga los primeros 100, sino los primeros 100 del select que hayas usado.
O sea, que si pones:

Código SQL [-]
select first 100 from tbClientes where telefono containing '123'

Te traerá los primeros 100 que cumplan esa condición.
Responder Con Cita
  #4  
Antiguo 13-08-2012
n03l n03l is offline
Miembro
 
Registrado: feb 2007
Posts: 73
Poder: 18
n03l Va por buen camino
Ok Muchas Gracias, Me sirvio bastante su ayuda..
Responder Con Cita
  #5  
Antiguo 14-08-2012
Avatar de Cañones
Cañones Cañones is offline
Miembro
 
Registrado: ene 2007
Ubicación: La Paz Entre Ríos
Posts: 354
Poder: 18
Cañones Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Al usar First 100 no le estás diciendo que traiga los primeros 100, sino los primeros 100 del select que hayas usado.

Te traerá los primeros 100 que cumplan esa condición.
No sabía de la existencia del comando first.
Gracias.
Responder Con Cita
  #6  
Antiguo 15-08-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Y también puedes indicarle que se sale una cantidad de registros, ejemplo:

Código SQL [-]
select first 100 skip 5 * from tbclientes
Responder Con Cita
  #7  
Antiguo 15-08-2012
Avatar de Chris
[Chris] Chris is offline
Miembro Premium
 
Registrado: abr 2007
Ubicación: Jinotepe, Nicaragua
Posts: 1.678
Poder: 19
Chris Va por buen camino
Cita:
Empezado por Cañones Ver Mensaje
No sabía de la existencia del comando first.
Gracias.
Los alteradores FIRST y SKIP se utilizan para realizar paginadores. Los clásicos: Ver página 1 de 100 de Google.

Saludos.
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
Respuesta



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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
propiedad booleana de radiogroup PaulaGV OOP 2 28-05-2012 12:50:28
uso del IBDataSet Giniromero Conexión con bases de datos 21 10-07-2006 00:12:47
Problemas con IbdataSet perillan Conexión con bases de datos 0 01-04-2005 19:38:44
Duda con ibDataset de IBX AGAG4 SQL 2 20-08-2004 03:00:56
IbTable o IbDataset NickName Firebird e Interbase 4 13-09-2003 04:13:26


La franja horaria es GMT +2. Ahora son las 13:41:06.


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