SQLの練習問題です。
筆者の環境は以下となっていますが、別のデータベースやツールでもほとんど同じように動作すると思います。
- MariaDB 5.5.48
- MySQL Workbench 6.3
よくわからないという方は、XAMPをインストールすると簡単に筆者と同じ環境を構築できます。以下のページで紹介されています。
【PHP入門】環境構築
問題として使用するデータは以下からダウンロード可能です。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
連載目次リンク
関連する連載リンク
WEBアプリケーション関連 人気連載リンク
データベースの基礎が学べるSQL基礎講座
SQL基礎 連載
より実践的なWEBアプリ開発講座!Bootstrap活用を学ぶなら・・
魁!小野の塾 連載