Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-06-2004
cmena cmena is offline
Miembro
 
Registrado: abr 2004
Ubicación: CHILE
Posts: 67
Poder: 21
cmena Va por buen camino
Question como cuento los reg. de un query?

hola:
hago un select como cuento los reg del query?
estoy dando mis primeros pasos por sql
gracias
Responder Con Cita
  #2  
Antiguo 23-06-2004
Ruben_Cu Ruben_Cu is offline
No confirmado
 
Registrado: oct 2003
Ubicación: Mariel, Cuba
Posts: 271
Poder: 0
Ruben_Cu Va por buen camino
Hola cmena, si ya tienes el resultado de tu query puedes usar la propiedad RecordCount del DataSet e implementarla así:
Código:
Edit1.Text:=IntToStr(TuQuery.RecordCount);
En el Edit1 aparecerá la cantidad de registros devuelto por tu condición de busqueda.
Saludos
Responder Con Cita
  #3  
Antiguo 23-06-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cool

Hola.

Un método que podria ser mas eficiente (dependiendo de la cantidad de registros devueltos por tu query original), es simplemente lanzar un Select count(*), con la misma clausula from y where de tu primer query.

De esta forma evitas que los registros viajen al cliente, y el servidor aprovechará al máximo los indices y otros recursos disponibles para contarlos.

Si solo son unos cuantos registros... digamos no mas de mil, no veo mucha ventaja en mi método, con lo que el del cubano Rubén Acosta sigue siendo válido.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #4  
Antiguo 23-06-2004
cmena cmena is offline
Miembro
 
Registrado: abr 2004
Ubicación: CHILE
Posts: 67
Poder: 21
cmena Va por buen camino
Question count

hola :
ejecute el count sobre 12.000 registros igual se demora como 3 minutos
el count lo podria hacer sobre el query? o habria otra forma para mas rapidez, este se demora igual que la opcion propuesta por el cubano.
estoy trabajando con dbf/cdx y un motor advantage.

Cita:
Empezado por jachguate
Hola.

Un método que podria ser mas eficiente (dependiendo de la cantidad de registros devueltos por tu query original), es simplemente lanzar un Select count(*), con la misma clausula from y where de tu primer query.

De esta forma evitas que los registros viajen al cliente, y el servidor aprovechará al máximo los indices y otros recursos disponibles para contarlos.

Si solo son unos cuantos registros... digamos no mas de mil, no veo mucha ventaja en mi método, con lo que el del cubano Rubén Acosta sigue siendo válido.

Hasta luego.

Responder Con Cita
  #5  
Antiguo 23-06-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Te sugiero que leas la documentación de tu motor para conocer sus capacidades al hacer joins u otras operaciones que involucre tu sentencia Select. Te se decir que con Oracle, teniendo los indices necesarios, una sentencia que involucre unas cuantas tablas y que cuente unos 12,000 registros no tardaría mas que unos 2 o 3 segundos.

Como ves, ya eso está fuera del alcance de delphi... depende del motor.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #6  
Antiguo 23-06-2004
cmena cmena is offline
Miembro
 
Registrado: abr 2004
Ubicación: CHILE
Posts: 67
Poder: 21
cmena Va por buen camino
count

Cita:
Empezado por jachguate
Te sugiero que leas la documentación de tu motor para conocer sus capacidades al hacer joins u otras operaciones que involucre tu sentencia Select. Te se decir que con Oracle, teniendo los indices necesarios, una sentencia que involucre unas cuantas tablas y que cuente unos 12,000 registros no tardaría mas que unos 2 o 3 segundos.

Como ves, ya eso está fuera del alcance de delphi... depende del motor.

Hasta luego.


juan me olvide de decir que dentro del select tengo una subconsulta, no saldria mas rapido hacer un select count sobre el anterior query? se puede?
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


La franja horaria es GMT +2. Ahora son las 16:43:34.


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