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
  #41  
Antiguo 17-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
y en cuento a los resultados de la sentencia, me devuelve el mismo resultado que en mi consulta inicial, lo que hemos hecho no es mas que convertir mi consulta utilizando INNER JOIN.
Responder Con Cita
  #42  
Antiguo 17-09-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.079
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
A ver, la pregunta exacta es:
Cita:
necesito hacer una consulta que me selecione por carro los km recorrido y el consumo en un rango de fecha 1/9/2012-30/9/2012
ahora vuelvo...
Responder Con Cita
  #43  
Antiguo 17-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Hola, buen día.

Esta consulta preparada en el diseñador de consulta del Access está probada y funciona; hecha de acuerdo a las especificaciones de la tabla dada en el primer mensaje de este tema.

La tarea final es implementarlo en el Delphi.

Insisto en que el form se coloquen 2 componentes TDateTimePicker o similar; en todo caso pueda pasar la fecha en formato que Access reconozca.

Código SQL [-]
SELECT C.IDCARRO, C.NOCARRO, C.indececons, Sum(DHR.KMRECORRIDO) AS SumaDeKMRECORRIDO, Sum(CO.CONSUMO) AS SumaDeCONSUMO
FROM CARRO AS C, HOJARUTA AS HR, DESCHOJARUTA AS DHR, CONSUMO AS CO
WHERE (((CO.FECHA) Between [:FECHA1] And [:FECHA2])
  AND  HR.IDCARRO = C.IDCARRO
  AND DHR.IDHOJARUTA = HR.IDHOJARUTA 
  AND CO.IDCARRO = C.IDCARRO)
  
GROUP BY C.IDCARRO, C.NOCARRO, C.indececons
ORDER BY C.IDCARRO;

Espero que sea de ayuda.

Saludos.
Responder Con Cita
  #44  
Antiguo 17-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
He probado la consulta en access se ejecuta sin ningun error aunque no me devuelve ningun valor , pero cuando la ejecuto desde el delphi me tira un error que dice ('Pocos Parametros. se esperaba 3.')
Responder Con Cita
  #45  
Antiguo 17-09-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.079
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Evidentemente algo está mal en tu código delphi.
Responder Con Cita
  #46  
Antiguo 17-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Hola,

Entiendo que ya ejecutaste la última consulta SQL que te envié.

Al probar en el SQL Vista SQL del Access te tiene que pedir 2 parámetros; el primer parámetro sería :FECHA1 y el segundo :FECHA2.

Si no da error y no trae nada quiere decir que no se tiene datos en la base de datos; si ese es el caso inserta algunos datos en todas las tablas involucradas CARRO, CONSUMO, HOJARUTA, DESCHOJARUTA.

En el Delphi tiene que pedir esos 2 parámetros mencionados y lo que se debe hacer es pasarle de manera correcta esas 2 fechas y debería funcionar.

Saludos.
Responder Con Cita
  #47  
Antiguo 17-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
los parametros de fecha se le pasan correctamente, pero me fije que cuendo corro la consulta en ACCESS me pide como parametro el C.indececons quisas ese sea el problema.
Responder Con Cita
  #48  
Antiguo 17-09-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.079
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Los parámetros son los que tienen los dos puntos delante:
Código SQL [-]
[:FECHA1] And [:FECHA2])

Por lo que si te pide eso como parámetro, es que le has puesto dos puntos.
Responder Con Cita
  #49  
Antiguo 17-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
desde delphi esta correcto el pase de los parametros FECHA1 y FECHA2, pero en la misma estructura de la sentencia SQL cuando la corro en ACCESS me pide como parametro c.indicecons que quisas al no asignarlo desde delphi ese sea el problema.

y entonces se crearia otro problem pues la consulta solo me puede pedir como parametro las fecha.

en cuanto a lo que decia hoyosfelix en el form lo que se escoge es el mes el cual lleba implisito el rago de fecha.
Responder Con Cita
  #50  
Antiguo 17-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Hola, ya me fije en ese detalle del Access.

Es raro el comportamiento del Access, no debería pedir el parámetro C.indicecons.

Probá de esta manera:


Código SQL [-]
SELECT C.idcarro, C.nocarro, C.indececons, Sum(DHR.kmrecorrido) AS SumaDeKMRECORRIDO, Sum(CO.consumo) AS SumaDeCONSUMO
FROM carro AS C, hojaruta AS HR, deschojaruta AS DHR, consumo AS CO
WHERE (((CO.fecha) Between [:FECHA1] And [:FECHA2]) AND ((HR.idcarro)=[C].[idcarro]) AND ((DHR.idhojaruta)=[HR].[idhojaruta]) AND ((CO.idcarro)=[C].[idcarro]))
GROUP BY C.idcarro, C.nocarro, C.indececons
ORDER BY C.idcarro;

Saludos...
Responder Con Cita
  #51  
Antiguo 17-09-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.079
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Se va a resistir bastante la consultita esa .

¿Has probado a quitar C.indececons, a ver qué mensaje sale?
Responder Con Cita
  #52  
Antiguo 17-09-2012
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Y, ¿no habrá manera de tener una copia reducida de la base para hacer pruebas? Digo, una copia con pocos datos pero con todas las tablas involucradas.

// Saludos
Responder Con Cita
  #53  
Antiguo 17-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Hola,

Realmente en la consulta

donde dice: C.indececons

debe decir: C.indicecons

Por esa razón es que el Access "piensa" que C.indececons es un parámetro.

Saludos.
Responder Con Cita
  #54  
Antiguo 17-09-2012
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cierto, en la descripción original de campos dice indicecons. ¡Buena vista! Lo raro es que Access marque ese error de parámetro en lugar de dicer que no reconoce ese identificador o campo.

// Saludos
Responder Con Cita
  #55  
Antiguo 17-09-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.079
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por roman Ver Mensaje
Lo raro es que Access marque ese error de parámetro en lugar de dicer que no reconoce ese identificador o campo.
Es para ponernos a prueba
Responder Con Cita
  #56  
Antiguo 17-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
tenian razon el error era c.indececons por c.indicecons,
probe y me sigue dando los datos erroneos como al principio
adjunto un estracto de mi base de dato
Archivos Adjuntos
Tipo de Archivo: rar bd_combustible.rar (33,7 KB, 3 visitas)
Responder Con Cita
  #57  
Antiguo 18-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Hola,

Bajé la BD y ejecuté! la consulta en Access, en el Diseñador de consultas SQL....y me trae el siguiente resultado:

Consulta1 idcarro nocarro indicecons SumaDeKMRECORRIDO SumaDeCONSUMO 15 TSA-590 10 4544 1550 16 TSD-455 4 800 150
Es decir, que tu base de datos efectivamente tiene datos...la consulta me funcionó a mí sin tantas modificaciones, excepto que corregí el campo C.indicecons en el SELECT y en el GROUP BY...

Favor aclarar si el error es en el Access o en Delphi?

Saludos...
Responder Con Cita
  #58  
Antiguo 18-09-2012
Salnhack Salnhack is offline
Miembro
NULL
 
Registrado: oct 2011
Ubicación: Cuba
Posts: 71
Poder: 13
Salnhack Va por buen camino
hola hoyosfelix, la consulta lo mismo en access que en delphi se ejecuta bien, el problema es que no devuelve los resultados correctamente, la consulta me tiene que dar asi
Código:
NO.CARRO          SUM(KMRECORRIDO)       SUM(CONSUMO)            
TSA-590                     1136                          510
TSA-455                      400                          150
Responder Con Cita
  #59  
Antiguo 18-09-2012
hoyosfelix hoyosfelix is offline
Miembro
 
Registrado: ago 2010
Ubicación: San Antonio, Paraguay
Posts: 38
Poder: 0
hoyosfelix Va por buen camino
Respuesta "Ayuda con consulta"

Buen día,

Eso es fácil. Quitar del SELECT los campos que no se necesiten, lo mismo que del GROUP BY.

Te dejo como tarea, para que fijes la idea.

Ya estamos cerca de la respuesta, el próximo post tiene que ser para avisar que ya encontraste la solución.

Saludos.
Responder Con Cita
  #60  
Antiguo 18-09-2012
cancun cancun is offline
Miembro
 
Registrado: may 2003
Ubicación: Cancun, México
Posts: 114
Poder: 22
cancun Va por buen camino
Hola


He estado siguiendo este hilo desde que empezó, no contesté por que mo encontré la manera de obtener el resultado que se quiere (estoy verde en SQL) pero quería ver como se resolvía, al parecer la sentencia que se ha logrado formar hasta ahora no da el resultado segun el compañero y podria ser por que en ningun lado se limita el rango de fechas para la tabla deschojaruta, creo que la consulta seria mas sencilla si a esta tabla tuviera un campo idcarro y ya no seria necesario incluir la tabla hojaruta, bueno a lo mejor estoy mal y espero que pronto se obtenga la sentencia correcta.


Saludos
__________________
Cancun, Q.Roo, México
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
Ayuda con consulta SQL n03l SQL 4 18-04-2007 22:03:40
Ayuda con consulta raco Varios 6 06-04-2005 02:14:25
Ayuda con consulta SQL tgsistemas SQL 9 18-02-2004 16:14:07
Ayuda con consulta JorgeBec SQL 7 21-10-2003 20:25:16
ayuda en consulta bismarito Firebird e Interbase 1 29-07-2003 00:40:45


La franja horaria es GMT +2. Ahora son las 00:56:05.


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