SQLZOO答案-SELECT within SELECT Tutorial2

SQL查询技巧精粹

上次那篇没有写完,此版是补充版

 

6.哪些國家的GDP比Europe歐洲的全部國家都要高呢? [只需列出 name 。] (有些國家的記錄中,GDP是NULL,沒有填入資料的。)

SELECT name 
  FROM world
WHERE gdp >ALL (SELECT gdp FROM world WHERE continent = 'Europe' AND gdp > 0);

注:此处必须加gdp>0

7.在每一個州中找出最大面積的國家,列出洲份 continent, 國家名字 name 及面積 area。 (有些國家的記錄中,AREA是NULL,沒有填入資料的。)

SELECT continent, name, area 
  FROM world x
WHERE area >=ALL (SELECT area FROM world y WHERE y.continent = x.continent AND area > 0

 

8.列出洲份名稱,和每個洲份中國家名字按子母順序是排首位的國家名。(即每洲只有列一國)

SELECT continent, name 
  FROM world x
WHERE x.name = (SELECT y.name FROM world y WHERE x.continent = y.continent LIMIT 1)

 

9.找出洲份,當中全部國家都有少於或等於 25000000 人口. 在這些洲份中,列出國家名字namecontinent 洲份和population人口。

SELECT name, continent, population
  FROM world x
WHERE  25000000 >=ALL  (SELECT y.population FROM world y WHERE x.continent = y.continent)

10.有些國家的人口是同洲份的所有其他國的3倍或以上。列出 國家名字name 和 洲份 continent。

SELECT name, continent
  FROM world x
WHERE x.population/3 >=ALL (SELECT y.population FROM world y 
  WHERE x.name <> y.name AND x.continent = y.continent)

 

### SQLZOO 使用指南 SQLZOO 是一个在线学习 SQL 的平台,提供了一系列的练习题和教程,帮助用户掌握 SQL 查询语言。以下是关于 SQLZOO 的使用方法及教程内容的详细介绍。 #### 1. 平台概述 SQLZOO 提供了从基础到级的 SQL 学习路径,涵盖了 SELECT 基础、JOIN 操作、聚合函数(如 SUM 和 COUNT)、NULL 处理以及更多复杂查询技巧。用户可以通过其提供的交互式界面直接编写和运行 SQL 代码[^1]。 #### 2. 主要教程模块 以下是 SQLZOO 的主要教程模块及其功能描述: - **SELECT 基础** 这一模块专注于 SQL 中最基本的 SELECT 语句,帮助用户理解如何从数据库中提取数据[^2]。 - **SELECT from WORLD Tutorial** 在这一部分,用户将学习如何从一个名为 `WORLD` 的数据库中查询国家信息,例如人口、面积等[^2]。 - **SELECT from Nobel Tutorial** 该模块通过诺贝尔奖得主的数据集,教授如何进行条件筛选和排序操作[^2]。 - **SELECT within SELECT Tutorial** 教授嵌套查询的用法,即在一个查询中使用另一个查询的结果作为条件[^2]。 - **SUM and COUNT** 针对聚合函数的使用,包括统计总数、求和等功能。 - **The JOIN operation** 讲解如何使用 JOIN 将多个表的数据组合在一起。 - **More JOIN operations** 深入探讨更复杂的 JOIN 操作,例如 LEFT JOIN、RIGHT JOIN 等。 - **Using Null** 介绍如何处理数据库中的 NULL 值,包括判断和替换 NULL 的方法[^2]。 - **Self join** 展示如何在同一个表内进行自连接操作,以解决特定的查询需求。 #### 3. 注意事项 - SQL 不区分大小写,因此在书写时可以灵活调整格式[^1]。 - 如果遇到中文版题目检测有误的情况,建议切换至英文原版进行验证。 - 对于字符串连接操作,可以使用 `CONCAT` 函数,但需要注意任一参数为 NULL 时,结果也会是 NULL[^3]。 #### 4. 示例代码 以下是一个简单的 SQL 查询示例,展示如何从 `world` 数据库中查找包含所有元音字母且不包含空格的国家名称: ```sql SELECT name FROM world WHERE name LIKE '%a%' AND name LIKE '%e%' AND name LIKE '%i%' AND name LIKE '%o%' AND name LIKE '%u%' AND name NOT LIKE '% %'; ``` 此代码片段来源于 SQLZOO 的练习题之一[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值