SUM and COUNT/ja

From SQLZoo

世界各国のプロフィール: 集計関数

このチュートリアルでは COUNT, SUM , AVG などの集計関数を扱う。集計関数は多数の値から1つの値を計算する。例えば、関数 SUM は 2, 4 ,5 から1つの値 11 を計算する。

namecontinentarea populationgdp
AfghanistanAsia6522302550010020343000000
AlbaniaEurope28748 2831741 12960000000
AlgeriaAfrica2381741 37100000 188681000000
AndorraEurope46878115 3712000000
AngolaAfrica1246700 20609294 100990000000
...

以下の例を見ておくとよい。

SUM, Count, MAX, DISTINCT と ORDER BY の利用

世界人口のトータル

1.

世界の総人口を表示。(各国の人口を合計)

world(name, continent, area, population, gdp)
SELECT SUM(population)
FROM world
SELECT SUM(population)
FROM world
result

大陸のリスト

2.

大陸名を重複しないように表示。

SELECT DISTINCT(continent)
FROM world
result

アフリカのGDP

3.

アフリカAfrica の各国のgdpの合計を求める。

SELECT SUM(gdp)
FROM world
WHERE continent = 'Africa'
result

大きな国の数

4.

面積が少なくとも 1000000 以上の国の数を求める。

SELECT COUNT(name)
FROM world
WHERE area >= 1000000
result

バルト三国の人口

5.

'Estonia', 'Latvia', 'Lithuania' の人口合計を求める。

SELECT SUM(population)
FROM world
WHERE name IN ('Estonia', 'Latvia', 'Lithuania')
result

GROUP BY と HAVING の使用方法

この例を見てもよい: Using GROUP BY and HAVING./ja

各大陸の国の数を数える

6.

各大陸continentごとに大陸名continentとそこの国の数を表示する。

SELECT continent, COUNT(name)
FROM world
GROUP BY(continent)
result

各大陸の大きな国を数える

7.

各大陸の人口が10000000人以上の国を数え、大陸名とその数を表示する。

SELECT continent, COUNT(name)
FROM world
WHERE population >= 10000000
GROUP BY(continent)
result

大きな大陸を数える

8.

その大陸の各国の人口の合計が100000000人以上の大陸のリストを表示する

SELECT continent
FROM world
GROUP BY continent
HAVING SUM(population)>= 100000000
result

ノーベル賞テーブルをさらに SUM と COUNT の練習で使う

次のチュートリアルではサッカーのデータベースで、2つの関連するテーブルのレコードを扱うクエリを説明する