SQL練習問題 – 問32

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


SQLの練習問題です。

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

  • MariaDB 5.5.48
  • MySQL Workbench 6.3

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

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

※データの誤りがありましたので、既にインポートされた方も改めて再インポートをお願いします。※ 2016/07/15


問題:
オウンゴールとなったゴールを抽出してください。goalsテーブルのplayer_idカラムにNULLが格納されているデータがオウンゴールを表しています。


ws000020

正解:

SELECT * 
FROM goals
WHERE player_id IS NULL 


「選択」を行うSQLの別バリエーションです。NULLが格納されているデータを条件として抽出したい場合には「player_id IS NULL」というように「IS NULL」を使用します。くれぐれも「= NULL」としないようにしましょう。実際に「= NULl」とした場合を試していただければわかりますが、SQLエラーになるわけではなく抽出件数がゼロ(すなわち該当データなし)となります。複雑な抽出条件を設定している場合など、机上だけでSQLを作成していると間違いに気づきにくいため注意が必要です。

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

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

PAGE TOP