SQL練習問題 – 問48


SQLの練習問題です。

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

  • MariaDB 5.5.48
  • MySQL Workbench 6.3

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

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


問題:
出場国の国名が長いものから順に出力してください。


正解:

SELECT name, LENGTH(name) 
FROM countries
ORDER BY LENGTH(name) DESC


文字列の長さを求めるためにはLENGTH関数(単一行関数)を使用することで可能です。
問題は「国名が長いものから順に」という指示がありますので、ORDER BY句を併用することになります。回答例のようにORDER BY句でも単一行関数を使用することができます。

そのほかの使用方法に関してはマニュアルがありますので、こちらを参照してください。
https://dev.mysql.com/doc/refman/5.6/ja/string-functions.html#function_length

似たような関数にはCHAR_LENGTHというものもあります。
https://dev.mysql.com/doc/refman/5.6/ja/string-functions.html#function_char-length

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

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

PAGE TOP