SQLZOO答案之【More JOIN operations】

这篇博客详细介绍了在SQLZOO上进行的各种JOIN操作,涵盖了从基础的电影信息查询到复杂的演员与电影关系的深入分析。内容包括查询1962年的电影、特定电影的上映年份、Star Trek系列电影、指定ID电影的名称,以及演员Glenn Close、Harrison Ford、Julie Andrews的相关电影信息等。此外,还涉及了电影角色数量统计、合作演员查找等多个实战练习。

在这里插入图片描述

1. 列出1962年首影的電影, [顯示 id, title]
SELECT  id, title
 FROM movie
 WHERE yr=1962;
2. 電影大國民 ‘Citizen Kane’ 的首影年份。
SELECT yr
FROM movie
WHERE title =  'Citizen Kane'
3. 列出全部Star Trek星空奇遇記系列的電影,包括id, title 和 yr(此系統電影都以Star Trek為電影名稱的開首)。按年份順序排列。
SELECT id, title, yr
FROM movie
WHERE title like 'Star Trek%'
ORDER BY yr;
4. id是 11768, 11955, 21191 的電影是什麼名稱?
SELECT title
FROM movie
WHERE id in ('11768', '11955', '21191');
5. 女演員’Glenn Close’的編號 id是什麼?
SELECT id 
FROM actor
WHERE name = 'Glenn Close';
### 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、付费专栏及课程。

余额充值