Tips

SQL練習問題 – 問1

SQL練習問題 – 問1

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練習問題 一覧まとめ

関連する連載リンク

SQL基礎 連載目次

WEBアプリケーション関連 人気連載リンク

データベースの基礎が学べるSQL基礎講座
SQL基礎 連載

より実践的なWEBアプリ開発講座!Bootstrap活用を学ぶなら・・
魁!小野の塾 連載

Recent News

Recent Tips

Tag Search