SQL練習問題 – 問1

この記事は2016年4月30日に書かれたものです。内容が古い可能性がありますのでご注意ください。


SQLの練習問題です。

筆者の環境は以下となっていますが、別のデータベースやツールでもほとんど同じように動作すると思います。

  • MariaDB 5.5.48
  • PhpMyAdmin 4.4.15.1

よくわからないという方は、XAMPをインストールすると簡単に筆者と同じ環境を構築できます。以下のサイトで紹介されています。
WINDOWS XAMPP にて LARAVEL をインストール (XAMPP V1.8.3インストール)

問題として使用するデータは以下からダウンロード可能です。phpMyAdminからデータベース(worldcup2014)を作成しインポートしておいてください。
worldcup2014.zip

各テーブルの説明は以下の通りです。
WS000000

WS000001

WS000006

WS000003


問題:各グループの中でFIFAランクが最も高い国と低い国のランキング番号を表示してください。

WS000004

正解:

SELECT group_name AS グループ, MIN(ranking) AS ランキング最上位, MAX(ranking) AS ランキング最下位
FROM countries
GROUP BY group_name

グループ化とグループ関数を使った基礎的な問題です。
FIFAランクとグループ情報はどちらもcountriesテーブルにありますので、テーブル結合などを行う必要はなくgroup_name列でグループ化し、ranking列でグループ関数を使えばOKです。
意外と勘違いしやすいポイントとして、MIN()関数を使った方がランキング最上位、MAX()関数を使った方がランキング最下位となりますので注意しましょう。

← SQL練習問題 一覧まとめに戻る

  • このエントリーをはてなブックマークに追加

PAGE TOP