Manipolazione dei dati in SQL
Mona Khalil
Data Scientist, Greenhouse Software
SELECT, FROM, WHERESELECT
s.stage,
ROUND(s.avg_goals,2) AS avg_goal,
(SELECT AVG(home_goal + away_goal)
FROM match WHERE season = '2013/2014') AS overall_avg
FROM
(SELECT
stage,
AVG(home_goal + away_goal) AS avg_goals
FROM match
WHERE season = '2013/2014'
GROUP BY stage) AS s
WHERE
s.avg_goals > (SELECT AVG(home_goal + away_goal)
FROM match WHERE season = '2013/2014');
SELECT, FROM, WHERE e GROUP BYSELECT
col1,
col2,
col3
FROM table1
WHERE col1 = 2;
/* Questa query filtra per col1 = 2
e seleziona solo dati da table1 */
SELECT
col1,
col2,
col3
FROM table1
WHERE col1 = 2;
SELECT
col1,
col2,
col3
FROM table1 -- questa tabella ha 10.000 righe
WHERE col1 = 2; -- Filtro WHERE valore 2
SELECT
col1,
col2,
col3
FROM table1
WHERE col1 IN
(SELECT id
FROM table2
WHERE year = 1991);
SELECT
date,
hometeam_id,
awayteam_id,
CASE WHEN hometeam_id = 8455 AND home_goal > away_goal
THEN 'Chelsea home win'
WHEN awayteam_id = 8455 AND home_goal < away_goal
THEN 'Chelsea away win'
WHEN hometeam_id = 8455 AND home_goal < away_goal
THEN 'Chelsea home loss'
WHEN awayteam_id = 8455 AND home_goal > away_goal
THEN 'Chelsea away loss'
WHEN (hometeam_id = 8455 OR awayteam_id = 8455)
AND home_goal = away_goal THEN 'Chelsea Tie'
END AS outcome
FROM match
WHERE hometeam_id = 8455 OR awayteam_id = 8455;
Le sottoquery richiedono potenza di calcolo
La sottoquery è davvero necessaria?
SELECT
s.stage,
ROUND(s.avg_goals,2) AS avg_goal,
(SELECT AVG(home_goal + away_goal)
FROM match WHERE season = '2013/2014') AS overall_avg
FROM
(SELECT
stage,
AVG(home_goal + away_goal) AS avg_goals
FROM match
WHERE season = '2013/2014'
GROUP BY stage) AS s
WHERE
s.avg_goals > (SELECT AVG(home_goal + away_goal)
FROM match WHERE season = '2013/2014');
Manipolazione dei dati in SQL