![](https://cdn-ak-scissors.b.st-hatena.com/image/square/e381c47f5bcaf18d3670508a2c74626ed1d0662e/height=288;version=1;width=512/https%3A%2F%2Fgihyo.jp%2Fassets%2Fimages%2FICON%2F2009%2F431_sql_academy2.png)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
第1回 連番の特性を利用してデータ操作をもっと自由に SQLで連番を扱う (3)メジアンを求める | gihyo.jp
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
第1回 連番の特性を利用してデータ操作をもっと自由に SQLで連番を扱う (3)メジアンを求める | gihyo.jp
集合指向的な解法 昔から知られている集合指向的な解法では、テーブルを上位集合と下位集合に分割してそ... 集合指向的な解法 昔から知られている集合指向的な解法では、テーブルを上位集合と下位集合に分割してその共通部を取ります(リスト9)。この解法のポイントは、HAVING句にあります。CASE式で表現された2つの特性関数によって、母集合Weightsを上位集合と下位集合に分割しているのです(図4)。これはこれで「SQLらしい」解答ではあります。 リスト9 メジアンを求める(集合指向型):母集合を上位と下位に分割する SELECT AVG(weight) FROM (SELECT W1.weight FROM Weights W1, Weights W2 GROUP BY W1.weight --S1(下位集合)の条件 HAVING SUM(CASE WHEN W2.weight >= W1.weight THEN 1 ELSE 0 END) >= COUNT(*) / 2 --S2(