SQL zoo(zh)习题记录Ⅰ

SELECT basics/zh

這個教程介紹SQL語言。我們會使用SELECT語句。我們會使用WORLD表格
name continent area population gdp
Afghanistan Asia 652230 25500100 20343000000
Albania Europe 28748 2831741 12960000000

name:國家名稱
continent:洲份
area:面積
population:人口
gdp:國內生產總值

1.修改此例子,以顯示德國 Germany 的人口。

這個例子顯示’France法國’的人口。字串應該在’單引號’中。
SELECT population FROM world WHERE name = ‘Germany’

Per Capita GDP

2.查詢顯示面積為 5,000,000 以上平方公里的國家,該國家的人口密度(population/area)。人口密度並不是 WORLD 表格中的欄,但我們可用公式(population/area)計算出來。
修改此例子,查詢面積為 5,000,000 以上平方公里的國家,對每個國家顯示她的名字和人均國內生產總值(gdp/population)。
SELECT name, gdp/population FROM world WHERE area > 5000000

Scandinavia

3.檢查列表:單詞“IN”可以讓我們檢查一個項目是否在列表中。此示例顯示了“Luxembourg 盧森堡”,“Mauritius 毛里求斯”和“Samoa 薩摩亞”的國家名稱和人口。
顯示“Ireland 愛爾蘭”,“Iceland 冰島”,“Denmark 丹麥”的國家名稱和人口。
SELECT name, population FROM world WHERE name IN (‘Ireland’, ‘Iceland’, ‘Denmark’);

Just the right size

4.哪些國家是不是太小,又不是太大?
BETWEEN 允許範圍檢查 - 注意,這是包含性的。 此例子顯示面積為 250,000 及 300,000 之間的國家名稱和該國面積。
修改此例子,以顯示面積為 200,000 及 250,000 之間的國家名稱和該國面積。
SELECT name, area FROM world WHERE area BETWEEN 200000 AND 250000

SELECT names/zh

name continent
Afghanistan Asia
Albania Europe

name:國家名稱
continent:洲份

Pattern Matching Strings

此教程使用LIKE運算子來檢查國家名字,我們會在world表格中運用SELECT語句:

1.找出以 Y 為開首的國家。

你可以用WHERE name LIKE 'B%'來找出以 B 為開首的國家。%是萬用字元,可以用代表任何字完。
SELECT name FROM world WHERE name LIKE ‘Y%’

2.找出以 Y 為結尾的國家。

SELECT name FROM world WHERE name LIKE ‘%Y’

3.找出所有國家,其名字包括字母x。

“Luxembourg 盧森堡”中有一個x字母,還有一個國家的名字中有x。列出這兩個國家。
SELECT name FROM world WHERE name LIKE ‘%x%’

4.找出所有國家,其名字以 land 作結尾。

“Iceland 冰島”和“Switzerland 瑞士”的名字都是以”land”作結束的。還有其他嗎?
SELECT name FROM world WHERE name LIKE ‘%land’

5.找出所有國家,其名字以 C 作開始,ia 作結尾。

“Columbia 哥倫比亞”是以 C 作開始,ia 作結尾的。還有兩個國家相同。
SELECT name FROM world WHERE name LIKE ‘C%ia’

6.找出所有國家,其名字包括字母oo。

“Greece 希臘”中有雙 e 字。哪個國家有雙 o 字呢?
SELECT name FROM world WHERE name LIKE ‘%oo%’

7.找出所有國家,其名字包括三個或以上的a。

“Bahamas 巴哈馬”中有三個 a,還有嗎?
SELECT name FROM world WHERE name LIKE ‘%a%a%a%’

8.找出所有國家,其名字以t作第二個字母。

SELECT name FROM world WHERE name LIKE ‘_t%’
ORDER BY name
“India 印度”和”Angola 安哥拉”的第二個字母都是 n。
你可以用底線符_當作單一個字母的萬用字元。
SELECT name FROM world WHERE name LIKE ‘_n%’
ORDER BY name

9.找出所有國家,其名字都有兩個字母 o,被另外兩個字母相隔着。

“Lesotho 賴索托”和”Moldova 摩爾多瓦”都有兩個字母 o,被另外兩個字母相隔着。
SELECT name FROM world WHERE name LIKE ‘%o__o%’

10.找出所有國家,其名字都是 4 個字母的。

“Cuba古巴”和”Togo 多哥”都是 4 個字母。
SELECT name FROM world WHERE name LIKE ‘____’

更困難的問題
如你覺得以上題目太容易了,非常好。Well done for getting this far. 下面的題目更困難,更有挑戰性!

11.顯示所有國家名字,其首都和國家名字是相同的。

“Luxembourg 盧森堡”的首都 capital 都同樣叫“Luxembourg”。
SELECT name FROM world WHERE name =capital

12.顯示所有國家名字,其首都是國家名字加上”City”。

“Mexico 墨西哥”的首都是”Mexico City”。concat函數
SELECT name FROM world where capital like concat(name, ’ city’)

13.找出所有首都和其國家名字,而首都要有國家名字中出現。

select capital,name from world where capital like concat(‘%’,name,‘%’)

14.找出所有首都和其國家名字,而首都是國家名字的延伸。

你應顯示 Mexico City,因它比其國家名字 Mexico 長。
你不應顯示 Luxembourg,因它的首都和國家名相是相同的。
select name,capital from world
where capital like concat(name,‘%’) and capital!= name

15.顯示國家名字,及其延伸詞,如首都是國家名字的延伸。

“Monaco-Ville"是合併國家名字 “Monaco” 和延伸詞”-Ville".
你可以使用SQL函數 REPLACE 或 MID.
SELECT name,replace(capital, name, ‘’) FROM world
WHERE capital LIKE concat(name,‘_%’)

相关推荐

  1. SQL zoo(zh)习题记录

    2024-03-16 07:18:04       21 阅读
  2. 数据库——习题

    2024-03-16 07:18:04       31 阅读
  3. springboot习题

    2024-03-16 07:18:04       9 阅读
  4. 计算机网络——习题

    2024-03-16 07:18:04       32 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-16 07:18:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-16 07:18:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-16 07:18:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-16 07:18:04       18 阅读

热门阅读

  1. 服务器生产环境问题解决思路

    2024-03-16 07:18:04       19 阅读
  2. MapReduce超详解

    2024-03-16 07:18:04       18 阅读
  3. CMake官方教程6--为CDash提供支持

    2024-03-16 07:18:04       17 阅读
  4. ZooKeeper 概述

    2024-03-16 07:18:04       24 阅读
  5. with open----bug

    2024-03-16 07:18:04       18 阅读
  6. 获取iOS和Android的app下载渠道和相关参数的方式

    2024-03-16 07:18:04       17 阅读
  7. 手写 UE4中的 TArray

    2024-03-16 07:18:04       17 阅读