Data Science Hub
  • Data Science Hub
  • STATISTICS
    • Introduction
    • Fundamentals
      • Data Types
      • Central Tendency, Asymmetry, and Variability
      • Sampling
      • Confidence Interval
      • Hypothesis Testing
    • Distributions
      • Exponential Distribution
    • A/B Testing
      • Sample Size Calculation
      • Multiple Testing
  • Database
    • Database Fundamentals
    • Database Management Systems
    • Data Warehouse vs Data Lake
  • SQL
    • SQL Basics
      • Creating and Modifying Tables/Views
      • Data Types
      • Joins
    • SQL Rules
    • SQL Aggregate Functions
    • SQL Window Functions
    • SQL Data Manipulation
      • String Operations
      • Date/Time Operations
    • SQL Descriptive Stats
    • SQL Tips
    • SQL Performance Tuning
    • SQL Customization
    • SQL Practice
      • Designing Databases
        • Spotify Database Design
      • Most Commonly Asked
      • Mixed Queries
      • Popular Websites For SQL Practice
        • SQLZoo
          • World - BBC Tables
            • SUM and COUNT Tutorial
            • SELECT within SELECT Tutorial
            • SELECT from WORLD Tutorial
            • Select Quiz
            • BBC QUIZ
            • Nested SELECT Quiz
            • SUM and COUNT Quiz
          • Nobel Table
            • SELECT from Nobel Tutorial
            • Nobel Quiz
          • Soccer / Football Tables
            • JOIN Tutorial
            • JOIN Quiz
          • Movie / Actor / Casting Tables
            • More JOIN Operations Tutorial
            • JOIN Quiz 2
          • Teacher - Dept Tables
            • Using Null Quiz
          • Edinburgh Buses Table
            • Self join Quiz
        • HackerRank
          • SQL (Basic)
            • Select All
            • Select By ID
            • Japanese Cities' Attributes
            • Revising the Select Query I
            • Revising the Select Query II
            • Revising Aggregations - The Count Function
            • Revising Aggregations - The Sum Function
            • Revising Aggregations - Averages
            • Average Population
            • Japan Population
            • Population Density Difference
            • Population Census
            • African Cities
            • Average Population of Each Continent
            • Weather Observation Station 1
            • Weather Observation Station 2
            • Weather Observation Station 3
            • Weather Observation Station 4
            • Weather Observation Station 6
            • Weather Observation Station 7
            • Weather Observation Station 8
            • Weather Observation Station 9
            • Weather Observation Station 10
            • Weather Observation Station 11
            • Weather Observation Station 12
            • Weather Observation Station 13
            • Weather Observation Station 14
            • Weather Observation Station 15
            • Weather Observation Station 16
            • Weather Observation Station 17
            • Weather Observation Station 18
            • Weather Observation Station 19
            • Higher Than 75 Marks
            • Employee Names
            • Employee Salaries
            • The Blunder
            • Top Earners
            • Type of Triangle
            • The PADS
          • SQL (Intermediate)
            • Weather Observation Station 5
            • Weather Observation Station 20
            • New Companies
            • The Report
            • Top Competitors
            • Ollivander's Inventory
            • Challenges
            • Contest Leaderboard
            • SQL Project Planning
            • Placements
            • Symmetric Pairs
            • Binary Tree Nodes
            • Interviews
            • Occupations
          • SQL (Advanced)
            • Draw The Triangle 1
            • Draw The Triangle 2
            • Print Prime Numbers
            • 15 Days of Learning SQL
          • TABLES
            • City - Country
            • Station
            • Hackers - Submissions
            • Students
            • Employee - Employees
            • Occupations
            • Triangles
        • StrataScratch
          • Netflix
            • Oscar Nominees Table
            • Nominee Filmography Table
            • Nominee Information Table
          • Audible
            • Easy - Audible
          • Spotify
            • Worldwide Daily Song Ranking Table
            • Billboard Top 100 Year End Table
            • Daily Rankings 2017 US
          • Google
            • Easy - Google
            • Medium - Google
            • Hard - Google
        • LeetCode
          • Easy
  • Python
    • Basics
      • Variables and DataTypes
        • Lists
        • Dictionaries
      • Control Flow
      • Functions
    • Object Oriented Programming
      • Restaurant Modeler
    • Pythonic Resources
    • Projects
  • Machine Learning
    • Fundamentals
      • Supervised Learning
        • Classification Algorithms
          • k-Nearest Neighbors
            • kNN Parameters & Attributes
          • Logistic Regression
        • Classification Report
      • UnSupervised Learning
        • Clustering
          • Evaluation
      • Preprocessing
        • Scalers: Standard vs MinMax
        • Feature Selection vs Dimensionality Reduction
        • Encoding
    • Frameworks
    • Machine Learning in Advertising
    • Natural Language Processing
      • Stopwords
      • Name Entity Recognition (NER)
      • Sentiment Analysis
        • Agoda Reviews - Part I - Scraping Reviews, Detecting Languages, and Preprocessing
        • Agoda Reviews - Part II - Sentiment Analysis and WordClouds
    • Recommendation Systems
      • Spotify Recommender System - Artists
  • Geospatial Analysis
    • Geospatial Analysis Basics
    • GSA at Work
      • Web Scraping and Mapping
  • GIT
    • GIT Essentials
    • Connecting to GitHub
  • FAQ
    • Statistics
  • Cloud Computing
    • Introduction to Cloud Computing
    • Google Cloud Platform
  • Docker
    • What is Docker?
Powered by GitBook
On this page
  • game Table
  • goal Table
  • eteam Table

Was this helpful?

  1. SQL
  2. SQL Practice
  3. Popular Websites For SQL Practice
  4. SQLZoo
  5. Soccer / Football Tables

JOIN Tutorial

Last updated 1 year ago

Was this helpful?

game Table

id
mdate
stadium
team1
team2

1001

8 June 2012

National Stadium, Warsaw

POL

GRE

1002

8 June 2012

Stadion Miejski (Wroclaw)

RUS

CZE

1003

12 June 2012

Stadion Miejski (Wroclaw)

GRE

CZE

1004

12 June 2012

National Stadium, Warsaw

POL

RUS

...

goal Table

matchid
teamid
player
gtime

1001

POL

Robert Lewandowski

17

1001

GRE

Dimitris Salpingidis

51

1002

RUS

Alan Dzagoev

15

1002

RUS

Roman Pavlyuchenko

82

...

eteam Table

id
teamname
coach

POL

Poland

Franciszek Smuda

RUS

Russia

Dick Advocaat

CZE

Czech Republic

Michal Bilek

GRE

Greece

Fernando Santos

...

  1. The first example shows the goal scored by a player with the last name 'Bender'. The * says to list all the columns in the table - a shorter way of saying matchid, teamid, player, gtime Modify it to show the matchid and player name for all goals scored by Germany. To identify German players, check for: teamid = 'GER'

SELECT matchid, player FROM goal WHERE teamid = 'GER'

  1. From the previous query you can see that Lars Bender's scored a goal in game 1012. Now we want to know what teams were playing in that match. Notice that the column matchid in the goaltable corresponds to the id column in the game table. We can look up information about game 1012 by finding that row in the game table. Show id, stadium, team1, team2 for just game 1012

SELECT id, stadium, team1, team2
FROM game
WHERE matchid = 1012

  1. Modify it to show the player, teamid, stadium and mdate for every German goal.

SELECT player, teamid, stadium, mdate
FROM game 
JOIN goal ON (id=matchid) AND teamid = 'GER'

  1. Use the same JOIN as in the previous question. Show the team1, team2 and player for every goal scored by a player called Mario player LIKE 'Mario%'

SELECT gm.team1, gm.team2, go.player
FROM game gm
JOIN goal go ON (gm.id=go.matchid)
WHERE player LIKE 'Mario%'

5. The table eteam gives details of every national team including the coach. You can JOIN goal to eteamusing the phrase goal JOIN eteam on teamid=id Show player, teamid, coach, gtime for all goals scored in the first 10 minutes gtime<=10

SELECT go.player, go.teamid, et.coach, go.gtime
FROM goal go
JOIN eteam et ON (go.teamid = et.id)
WHERE go.gtime <= 10

  1. To JOIN game with eteam you could use either game JOIN eteam ON (team1=eteam.id) or game JOIN eteam ON (team2=eteam.id) Notice that because id is a column name in both gameand eteam you must specify eteam.id instead of just id List the dates of the matches and the name of the team in which 'Fernando Santos' was the team1 coach.

SELECT gm.mdate, et.teamname
FROM game gm
JOIN eteam et ON (gm.team1 = et.id)
WHERE et.coach = 'Fernando Santos'

  1. List the player for every goal scored in a game where the stadium was 'National Stadium, Warsaw'

SELECT go.player
FROM game gm
JOIN goal go ON (gm.id=go.matchid)
WHERE gm.stadium = 'National Stadium, Warsaw'

  1. The example query shows all goals scored in the Germany-Greece quarterfinal. Instead show the name of all players who scored a goal against Germany.

Select goals scored only by non-German players in matches where GER was the id of either team1 or team2.

You can use teamid!='GER' to prevent listing German players.

You can use DISTINCT to stop players being listed twice.

SELECT DISTINCT go.player
FROM game gm
JOIN goal go ON gm.id=go.matchid AND (gm.team1 = 'GER' OR gm.team2 = 'GER')
WHERE go.teamid!='GER'

-- or
-- WHERE go.teamid != 'GER' AND (gm.team1 = 'GER' OR gm.team2='GER')

  1. Show teamname and the total number of goals scored.

SELECT et.teamname, COUNT(go.player) as goals_scored
FROM eteam et
JOIN goal go
ON et.id = go.teamid
GROUP BY et.teamname

  1. Show the stadium and the number of goals scored in each stadium.

SELECT gm.stadium, COUNT(go.player) as goals_scored
FROM game gm
JOIN goal go ON (gm.id=go.matchid)
GROUP BY gm.stadium

  1. For every match involving 'POL', show the matchid, date and the number of goals scored.

SELECT go.matchid, gm.mdate, COUNT(go.player) as goals_scored
FROM game gm
JOIN goal go 
ON gm.id = go.matchid AND (gm.team1 = 'POL' OR gm.team2 = 'POL')
GROUP BY go.matchid, gm.mdate

-- or
-- ON gm.id = go.matchid 
-- WHERE gm.team1 = 'POL' or gm.team2 = 'POL'

  1. For every match where 'GER' scored, show matchid, match date and the number of goals scored by 'GER'

SELECT go.matchid, gm.mdate, COUNT(go.player) as goals_scored
FROM game gm
JOIN goal go 
ON gm.id = go.matchid AND go.teamid = 'GER'
GROUP BY go.matchid, gm.mdate

-- or
-- ON goal.matchid = game.id
-- WHERE teamid = 'GER'

mdate
team1
score1
team2
score2

1 July 2012

ESP

4

ITA

0

10 June 2012

ESP

1

ITA

1

10 June 2012

IRL

1

CRO

3

...

Notice in the query given every goal is listed. If it was a team1 goal then a 1 appears in score1, otherwise there is a 0. You could SUM this column to get a count of the goals scored by team1. Sort your result by mdate, matchid, team1 and team2.

SELECT 
    gm.mdate, 
    gm.team1,
    SUM(CASE WHEN go.teamid = gm.team1 THEN 1 ELSE 0 END) AS score1,
    gm.team2,
    SUM(CASE WHEN go.teamid = gm.team2 THEN 1 ELSE 0 END) AS score2
FROM game gm
LEFT JOIN goal go ON gm.id = go.matchid
GROUP BY gm.mdate, gm.team1, gm.team2

List every match with the goals scored by each team as shown. This will use "" which has not been explained in any previous exercises.

Link
CASE WHEN