skillup

技術ブログ

Database

CASE+HAVING句

投稿日:

今回はCASEとHAVINGを組み合わせて、そこそこの難問を解いていきます。

まず下記のようなテーブル(testresults)があるとします。

student | class | sex | score
————–+——-+—–+——-
001 | A | 男 | 100
002 | A | 女 | 100
003 | A | 女 | 49
004 | A | 男 | 30
005 | B | 女 | 100
006 | B | 男 | 92
007 | B | 男 | 80
008 | B | 男 | 80
009 | B | 女 | 10
010 | C | 男 | 92
011 | C | 男 | 80
012 | C | 女 | 21
013 | D | 女 | 100
014 | D | 女 | 0
015 | D | 女 | 0

下記3題をCASEフラグとHAVINGで求めていきます。

コツとしては下記のようなことがあげられます。

  • 特定条件のの生徒をCASEで条件分岐させてフラグを立てる
  • さらにそれのSUMをとり、全体数と比較し、HAVINGで合致しているものを出力
  • SQLは割り算が整数になってしまうなどに注意。

なお下記SQLではSELECTの列で計算式をかいていますが、ここは書かなくてもOKです。(私が途中計算するうえでの確かめのために出してます。)

問題1
クラスの75%以上が80点以上のクラスを求めよ

答えはクラスBですが、

問題2
50点以上を取った生徒のうち、男子の数が女子の数よりも多いクラスを求めよ

クラスBとクラスCが該当。

第3問

女子の平均点が、男子の平均点より高いクラスを選択せよ。

-Database
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

論理設計のアンチパターン

今回からは論理設計のアンチパターンについて。 やってはいけない設計のパターンですね。これはまわりがやっていると気づかずにやっている可能性があるのでしっかりメモしておきたいです。 Contents1 非 …

no image

SQL 更新系に関して

SQL実践入門、残り2章になりましたが、いやーむずいっす。 今回は9章を進めていますがSQLはもともと検索を主な用途として発展したため、SELECT文の使用がメインになります。 ですが、UPDATE文 …

no image

jQuery modalダイアログについて&重複時間処理

Contents1 jqueryモーダルダイアログ1.1 あらかじめ読み込むライブラリ1.2 ソース本体1.2.1 Html側1.2.2 Javascript側1.2.3 参考リンク2 重複時間につい …

no image

アンチパターン データ分身の術+DBの不要な連携+バージョンアップ未テスト

今回のアンチパターンは主にデータ設計に関する部分。 Contents1 同一データの使用1.1 デメリット1.2 対策2 DBの不要な連携2.1 デメリット2.2 対策3 サーバーの移行やバージョンア …

no image

sql_modeに関して

開発では動いていたのに本番ではint型のカラムで空白が入らない!みたいなエラーが出て、データベースにデータが入らないことが発覚し、調査をすることに・・・ sql_modeが原因でした・・・ sql_m …

アーカイブ