SQLの練習問題です。
筆者の環境は以下となっていますが、別のデータベースやツールでもほとんど同じように動作すると思います。
- MariaDB 5.5.48
- MySQL Workbench 6.3
よくわからないという方は、XAMPをインストールすると簡単に筆者と同じ環境を構築できます。以下のページで紹介されています。
【PHP入門】環境構築
問題として使用するデータは以下からダウンロード可能です。phpMyAdminからデータベース(worldcup2014)を作成しインポートしておいてください。
worldcup2014.zip
※データの誤りがありましたので、既にインポートされた方も改めて再インポートをお願いします。※ 2016/07/15
問題:
オウンゴールとなったゴールを抽出してください。goalsテーブルのplayer_idカラムにNULLが格納されているデータがオウンゴールを表しています。
正解:
SELECT * FROM goals WHERE player_id IS NULL
「選択」を行うSQLの別バリエーションです。NULLが格納されているデータを条件として抽出したい場合には「player_id IS NULL」というように「IS NULL」を使用します。くれぐれも「= NULL」としないようにしましょう。実際に「= NULl」とした場合を試していただければわかりますが、SQLエラーになるわけではなく抽出件数がゼロ(すなわち該当データなし)となります。複雑な抽出条件を設定している場合など、机上だけでSQLを作成していると間違いに気づきにくいため注意が必要です。
連載目次リンク
関連する連載リンク
WEBアプリケーション関連 人気連載リンク
データベースの基礎が学べるSQL基礎講座
SQL基礎 連載
より実践的なWEBアプリ開発講座!Bootstrap活用を学ぶなら・・
魁!小野の塾 連載