SQLZOO JOIN答案

一系列SQL查询练习,涉及数据联接、筛选、聚合等操作,包括查找特定球队进球球员、比赛详细信息、教练信息、进球时间、比赛日期和场地等。

链接:https://sqlzoo.net/wiki/The_JOIN_operation
在这里插入图片描述

在这里插入图片描述
1.
在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

4.在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

SELECT eteam.teamname, COUNT(goal.player)
FROM eteam JOIN goal ON eteam.id=goal.teamid
GROUP BY(eteam.teamname)
ORDER BY eteam.teamname

在这里插入图片描述

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

在这里插入图片描述

SELECT goal.matchid, game.mdate, COUNT(goal.matchid) AS count
FROM game JOIN goal ON matchid = id 
WHERE (team1 = 'POL' OR team2 = 'POL')
GROUP BY goal.matchid, game.mdate

在这里插入图片描述

SELECT game.id, game.mdate, COUNT(game.id)
FROM game JOIN goal ON game.id=goal.matchid
WHERE goal.teamid='GER'
GROUP BY game.id, game.mdate

在这里插入图片描述

SELECT game.mdate, 
  game.team1, SUM(CASE WHEN goal.teamid=game.team1 THEN 1 ELSE 0 END) AS score1, 
  game.team2, SUM(CASE WHEN goal.teamid=game.team2 THEN 1 ELSE 0 END) AS score2
FROM game LEFT JOIN goal ON game.id=goal.matchid
GROUP BY game.mdate, game.id, game.team1,game.team2
ORDER BY game.mdate, game.id, game.team1, game.team2
### SQLZOO JOIN 练习解答 在处理数据库查询时,`JOIN` 是一种用于组合来自两个或多个表的数据的重要工具。对于 `LEFT JOIN` 和 `RIGHT JOIN` 的区别,在某些情况下,选择合适的连接方式可以极大地影响查询的结果集。 #### 左连接 (LEFT JOIN) 左连接返回左表中的所有记录以及右表中存在的匹配记录。如果右表中不存在匹配,则结果集中相应的列将包含 NULL 值[^1]。 ```sql SELECT A.column_name, B.column_name FROM TableA AS A LEFT JOIN TableB AS B ON A.common_field = B.common_field; ``` #### 右连接 (RIGHT JOIN) 右连接则相反,它会返回右表中的所有记录以及左表中存在的匹配记录。同样地,当左表缺少对应数据时,这些字段会被填充为 NULL。 ```sql SELECT A.column_name, B.column_name FROM TableA AS A RIGHT JOIN TableB AS B ON A.common_field = B.common_field; ``` 为了更好地理解如何应用这两种类型的联接操作,下面提供几个基于 SQLZOO 平台上的练习实例: ##### 示例 1: 查询世界人口超过五千五百万的国家及其所属大洲的人口总和 此问题可以通过执行内连接来解决,因为这里只需要考虑那些确实存在于两张表格内的条目;但是也可以通过其他形式的外键关联实现相同的功能。 ```sql SELECT continent, SUM(population) FROM world WHERE population > 55000000 GROUP BY continent; -- 或者使用 INNER JOIN 实现同样的效果 SELECT T1.continent, SUM(T2.population) FROM world AS T1 INNER JOIN world AS T2 ON T1.name = T2.name WHERE T2.population > 55000000 GROUP BY T1.continent; ``` ##### 示例 2: 列出欧洲各国首都名称与所在国名 这个问题适合采用左连接的方式来进行求解,即使有些国家可能暂时还没有定义其首都城市也不会丢失该国的信息。 ```sql SELECT country.name, city.name FROM country LEFT JOIN city ON country.capital = city.id WHERE country.continent='Europe'; ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值