CTE con subconsultas anidadas
Si incluyes varias subconsultas en la cláusula FROM con sentencia anidada, es probable que tu consulta se haga larga, compleja y difícil de leer.
Dado que muchas consultas se escriben con la intención de guardarlas y volver a ejecutarlas en el futuro, una organización adecuada es clave para un flujo de trabajo fluido. Organizar las subconsultas como CTE te ahorrará tiempo, espacio y confusión a largo plazo.
Este ejercicio forma parte del curso
Manipulación de datos en SQL
Instrucciones del ejercicio
- Declara una CTE que calcule los goles totales de los partidos disputados en agosto de la temporada
'2013/2014'. - Filtra la lista en la subconsulta interna para seleccionar solo los partidos disputados en agosto de la temporada
'2013/2014'. - Aplica
LEFT JOINa la CTE en la tabla de la liga utilizandocountry_idde la CTEmatch_list.
Ejercicio interactivo práctico
Prueba este ejercicio y completa el código de muestra.
-- Set up your CTE
___ match_list ___ (
SELECT
country_id,
(home_goal + away_goal) AS goals
FROM match
-- Create a list of match IDs to filter data in the CTE
WHERE id IN (
SELECT ___
FROM ___
WHERE season = ___ AND EXTRACT(MONTH FROM ___) = ___))
-- Select the league name and average of goals in the CTE
SELECT
___,
___(___)
FROM league AS l
-- Join the CTE onto the league table using country_id
LEFT JOIN ___ ON l.id = match_list.___
GROUP BY l.name;