SQLZOO:SELECT from WORLD Tutorial/zh
語言: | English • 日本語 • 中文 |
---|
name | continent | area | population | gdp |
---|---|---|---|---|
Afghanistan | Asia | 652230 | 25500100 | 20343000000 |
Albania | Europe | 28748 | 2831741 | 12960000000 |
Algeria | Africa | 2381741 | 37100000 | 188681000000 |
Andorra | Europe | 468 | 78115 | 3712000000 |
Angola | Africa | 1246700 | 20609294 | 100990000000 |
... |
name:國家名稱
continent:洲份
area:面積
population:人口
gdp:國內生產總值
Country Profile
在這教程中,我們會使用SELECT語句,對World
表格進行查詢。
閱讀此表的注意事項 觀察運行一個簡單的SQL命令的結果。
SELECT name, continent, population FROM world
SELECT name, continent, population FROM world
如何使用WHERE來篩選記錄。 顯示具有至少2億人口的國家名稱。 2億是200000000,有八個零。
SELECT name FROM world
WHERE population>250000000
SELECT name FROM world
WHERE population>200000000
找出有至少200百萬(2億)人口的國家名稱,及人均國內生產總值。
人均國內生產總值,即是國內生產總值除以人口(GDP/population)。
SELECT name, gdp/population FROM world
WHERE population > 200000000
顯示'South America'南美洲大陸的國家名字和以百萬為單位人口數。 將人口population 除以一百萬(1000000)得可得到以百萬為單位人口數。
SELECT name, population/1000000 FROM world
WHERE continent='South America'
顯示法國,德國,意大利(France, Germany, Italy)的國家名稱和人口。
SELECT name, population FROM world
WHERE name IN ('France','Germany','Italy')
顯示包含單詞“United”為名稱的國家。
SELECT name FROM world
WHERE name LIKE '%United%'
成為大國的兩種方式:如果它有3百萬平方公里以上的面積,或擁有250百萬(2.5億)以上人口。
展示大國的名稱,人口和面積。
select name,population,area
from world
where area>3000000
or population>250000000
美國、印度和中國(USA, India, China)是人口又大,同時面積又大的國家。排除這些國家。
顯示以人口或面積為大國的國家,但不能同時兩者。顯示國家名稱,人口和面積。
select name, population,area
from world
where
(population>250000000 or area>3000000)
and not(population>250000000 and area>3000000)
除以為1000000(6個零)是以百萬計。除以1000000000(9個零)是以十億計。使用 ROUND 函數來顯示的數值到小數點後兩位。
SELECT name, ROUND(population/1000000,2),
ROUND(gdp/1000000000,2)
FROM world
WHERE continent='South America'
顯示國家有至少一個萬億元國內生產總值(萬億,也就是12個零)的人均國內生產總值。四捨五入這個值到最接近1000。
顯示萬億元國家的人均國內生產總值,四捨五入到最近的$ 1000。
select name, ROUND(gdp/population,-3)
from world
where
gdp>1000000000000
困難的題目
The CASE statement shown is used to substitute North America for Caribbean in the third column.
SELECT name, continent,
CASE WHEN continent='Caribbean' THEN 'North America'
ELSE continent END
FROM world
WHERE name LIKE 'J%'
SELECT name, CASE WHEN continent='Oceania' THEN 'Australasia'
ELSE continent END
FROM world
WHERE name LIKE 'N%'
SELECT name, CASE WHEN continent IN ('Europe','Asia') THEN 'Eurasia'
WHEN continent IN ('North America','South America','Caribbean') THEN 'America'
ELSE continent END
FROM world
WHERE name BETWEEN 'A' AND 'C'
Put the continents right...
- Oceania becomes Australasia
- Countries in Eurasia and Turkey go to Europe/Asia
- Caribbean islands starting with 'B' go to North America, other Caribbean islands go to South America
SELECT name,continent,
CASE WHEN continent = 'Eurasia' OR name='Turkey' THEN 'Europe/Asia'
WHEN continent IN ('Oceania') THEN 'Australasia'
WHEN continent = 'Caribbean' AND name LIKE 'B%' THEN 'North America'
WHEN continent = 'Caribbean' THEN 'South America'
ELSE continent END
FROM world
ORDER BY name
What Next
- 測驗 World表格
- You can play a game: Find the duplicate
- 要繼續練習基本SQL語法,增加經驗,可以
在表格
nobel
中使用WHERE
語句 - 進階教程:你可以學習巢狀查詢(子查詢)。
在
world
表中,使用巢狀SELECT
語句