Ver Mensaje Individual
  #19 (permalink)  
Antiguo 09/11/2012, 12:21
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: 16 años, 5 meses
Puntos: 2658
Respuesta: Como enlazar multiples tablas. Optimizar consulta

Si entiendo correctamente, FACTURA es el encabezado de la factura, con los datos de la emisión de la misma, y FACTURAL, son los items correspondientes
Ahora bien, si eso es correcto, entonces la consulta así debería funcionar:
Código MySQL:
Ver original
  1. SELECT C.clacli, C.nombre, SUM(FL.precio) total
  2. FROM clientes C LEFT JOIN factura F ON C.clacli = C.clacli
  3.      INNER JOIN factural FL ON F.clafac = FL.clafac
  4. WHERE localidad='VIGO' AND YEAR(F.fecha)=2012
  5.      OR F.clafac IS NULL
  6. GROUP BY C.clacli
  7. ORDER BY total
En el segundo JOIN debe ponerse INNER JOIN y no LEFT JOIN, porque puede haber clientes sin factura, pero jamás puede existir una factura que no tenga items.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)