Ver Mensaje Individual
  #6 (permalink)  
Antiguo 11/02/2016, 11:42
Avatar de gnzsoloyo
gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Consulta sql de precio minimo por referencia

Cita:
me sale la primera marca que encuentra en vez de la marca que tenga el precio mas bajo
Es absolutamente natural... Por lo que veo, estás usando MySQL (asumo eso), y no conoces el funcionamiento de su lógica.
Este tema se ha tratado INFINIDAD de veces, y SIEMPRE damos la misma explicación...
El problema del GROUP BY es precisamente que usa el primer valor encontrado para ese o esos campos, y "esconde" los restantes resultados.
Si quieres algo que esté ordenado y agrupado, debes ordenar primero, y agrupar después. Adicionalmente, no estás ordenando en base a todos los criterios necesarios.
Código SQL:
Ver original
  1. SELECT fecha_rastreo, precio_comp0, marca0, referencia
  2. FROM
  3.     (SELECT
  4.        r.fecha_rastreo,
  5.        p0.precio precio_comp0,
  6.        p0.nombre_producto marca0,
  7.        p0.referencia
  8.     FROM datos_rastreo p0 INNER JOIN rastreo r ON p0.id_rastreo=r.id_rastreo
  9.     WHERE p0.tienda='ebay'
  10.     ORDER BY p0.precio DESC,  p0.nombre_producto ASC, fecha_rastreo ASC) Tabla1
  11. GROUP BY referencia, fecha_rastreo

Por cierto, los AS son innecesarios.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)