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 03-06-2011
servicomp servicomp is offline
Miembro
 
Registrado: oct 2003
Ubicación: Cartago
Posts: 153
Poder: 21
servicomp Va por buen camino
Como Usar los Index en una busqueda

Cordial saludo

Primero que todo estoy usando Firebird 2.5, delphi 2010 y usando Los conectores nativos.

Tengo una base de datos donde se encuentra una tabla con aproximadamente unos 78.000 registros, Los datos los hemos exportado desde un archivo XLS.

Uno de los campos de la tabla es identificación el cual es de tipo char, la información de los campos es casi toda numerica, pero tambien tenemos campos con codigos de numeros y letras.

Al tratar de hacer la consulta normal, me presenta el error, al parecer debido a que los datos no son solo númericos, por tal motivo he creado un Indice con el nombre USUARIO_IDX1, pero no se como usarlo en el momento que voy a realizar la busqueda usando un IBQuery

Código Delphi [-]
IBQCodigo.Close;
    IBQCodigo.SQL.Clear;
    IBQCodigo.SQL.Add('Select * from USUARIOS where DOCUMENTO='+Edit1.Text);
    IBQCodigo.Open;

El problema es que desconozco en que punto debemos de decirle que busque sobre el indice que ha sido creado con anterioridad en la tabla mediante el IB Expert

Código SQL [-]
CREATE INDEX USUARIOS_IDX1 ON USUARIOS (DOCUMENTO);

Agradeciendo de antemano la atención prestada


Macana
Responder Con Cita
  #2  
Antiguo 03-06-2011
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Los RDBMS cuando optimizan el código SQL crean un plan de ejecución en el cual deciden que índices utilizar, esta consulta es muy sensilla y sin dudas realizarán la búsqueda por el índice creado. Por otro lado, algunos motores permiten inyección de código con intrucciones al compilador para forzar el uso de ciertos índices, pero esto se suele usar para consultas mas complejas, donde conociendo el optimizador del motor, sabremos que utilizará algún juego de índices que no son los óptimos para la consulta que deseamos ejecutar.
Por otro lado, también es importante conocer como funciona nuestro motor, porque en la formulación de la consulta podemos ir definiendo por que tabla comenzar a ejecutar la consulta.

Saludos!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #3  
Antiguo 03-06-2011
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Deberías dar más información, servicomp, no dices qué error es el que sale, tampoco especificas el tipo de campo, sólo has dicho que es char, ¿un char?.
Responder Con Cita
  #4  
Antiguo 03-06-2011
servicomp servicomp is offline
Miembro
 
Registrado: oct 2003
Ubicación: Cartago
Posts: 153
Poder: 21
servicomp Va por buen camino
Bueno que pena con ustedes, cuanto hablo de un char, es una cadena de caracteres de 20.

En esl campo podemos encontrar información como estas '38840845', '3653117' o '1112766557', pero al momento de buscar alguno de es estos registros me dice que no se puede encontrar por que no es compatible el formato con 'V4K0250283'.

Es de anotar que 'V4K0250283', tambien es un valor del campo.

Es tambien aclarar que si la información la ordeno antes de ser cargada a la base de datos desde el archivo xls, funciona correctamente, por eso debo creo que lo soluciono colocando un indice, y que cuando necesito buscar un valor lo busque por el indice para que el error no salga


Agradeciendo de antemano la atención prestada

Macana
Responder Con Cita
  #5  
Antiguo 03-06-2011
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
Hola...

El problema está en como creas la sentencia select en tu código. Te faltan las comillas simples:

Código Delphi [-]
IBQCodigo.Close;
IBQCodigo.SQL.Clear;
IBQCodigo.SQL.Add('Select * from USUARIOS where DOCUMENTO = ''' + Edit1.Text + '''');
IBQCodigo.Open;

o también lo puedes hacer así:

Código Delphi [-]
IBQCodigo.SQL.Add(Format('Select * from USUARIOS where DOCUMENTO = ''%s''', [Edit1.Text]));


Saludos...
__________________
Lee la Guía de Estilo antes que cualquier cosa. - Twitter
Responder Con Cita
  #6  
Antiguo 03-06-2011
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Además de las opciones que ha dado maeyanes, puedes usar también:

Código Delphi [-]
IBQCodigo.SQL.Add('Select * from USUARIOS where DOCUMENTO ='+QuotedStr(Edit1.Text);

Y no te preocupes por el índice a usar, firebird sabe cual es mejor en cada momento.
Responder Con Cita
  #7  
Antiguo 03-06-2011
[maeyanes] maeyanes is offline
Capo de los Capos
 
Registrado: may 2003
Ubicación: Campeche, México
Posts: 2.732
Poder: 23
maeyanes Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Además de las opciones que ha dado maeyanes, puedes usar también:

Código Delphi [-]
IBQCodigo.SQL.Add('Select * from USUARIOS where DOCUMENTO ='+QuotedStr(Edit1.Text);

Y no te preocupes por el índice a usar, firebird sabe cual es mejor en cada momento.
Te faltó cerrar un paréntesis...

Código Delphi [-]
IBQCodigo.SQL.Add('Select * from USUARIOS where DOCUMENTO ='+QuotedStr(Edit1.Text));

Saludos...
__________________
Lee la Guía de Estilo antes que cualquier cosa. - Twitter
Responder Con Cita
  #8  
Antiguo 04-06-2011
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.040
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cierto, gracias
Responder Con Cita
  #9  
Antiguo 04-06-2011
Avatar de Delphius
[Delphius] Delphius is offline
Miembro Premium
 
Registrado: jul 2004
Ubicación: Salta, Argentina
Posts: 5.582
Poder: 25
Delphius Va camino a la fama
Entonces para cerrar:

1. El motor elige el índice más adecuado. En el caso de Firebird, se basa en una evaluación del costo. A cada índice se le asocia un valor entre 0 y 1. Cuando más cercano sea a 1, el índice es más óptimo.

2. Existen herramientas de terceros, como IBExperts y FlameRobin, que te informan del plan elegido. Este plan no es más que una descripción del índice elegido y el tipo de acción que seguido el motor para producir la consulta.

3. Es posible indicarle al motor el PLAN a asumir, aunque por lo general no es necesario. No recuerdo del todo bien, creo que la cláusula para ello es PLAN ...

Te recomendaría que leyeras la documentación. En el sitio oficial hay todo un arsenal de información.

Saludos,
__________________
Delphius
[Guia de estilo][Buscar]
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
Index is out of date... index table torito Conexión con bases de datos 7 10-12-2016 13:21:31
Como se asigna el index del checklistbox.... ronimaxh Varios 8 10-07-2007 20:17:14
como asigno el index de un checklisbox ronimaxh Varios 1 03-04-2007 21:27:38
Como realizar una busqueda? danytorres Varios 1 12-01-2004 17:14:43


La franja horaria es GMT +2. Ahora son las 21:54:46.


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