SQL で個々のグループの上位 2 つのスコアを取得する
リレーショナル データベースでは、大規模なデータセットから意味のあるデータを抽出する場合、多くの場合、レコードに基づいてグループ化する必要があります。特定の特性について。グループ化されたセットからデータを取得する場合、集計関数を使用して各グループ内の最高値または最低値を取得するのが一般的です。ただし、各グループの上位 N 行を選択する必要がある場合はどうすればよいでしょうか?
学生の名前と対応するスコアを含む次の表を考えてみましょう:
NAME | SCORE |
---|---|
willy | 1 |
willy | 2 |
willy | 3 |
zoe | 4 |
zoe | 5 |
zoe | 6 |
グループ化の集計関数で許可されるのは、各名前の最高スコアを取得します。各生徒の上位 2 つのスコアを取得するには、別のアプローチが必要です。
次のクエリは、サブクエリを使用してこれを実現し、それぞれのグループ内の各生徒のスコアのランクを追跡します。
SELECT * FROM test s WHERE ( SELECT COUNT(*) FROM test f WHERE f.name = s.name AND f.score >= s.score ) <p><strong>クエリの内訳:</strong></p>
- 外側のクエリ、 SELECT * FROM test s は、テスト テーブルからすべての行を取得し、それらを s としてエイリアスします。
-
括弧で囲まれたサブクエリは、各生徒のスコアのランクを計算します。
- SELECT COUNT(*) FROM test f: この部分は、名前 (f.name) が含まれるテスト テーブル内の行数をカウントします。現在の行の名前 (s.name) と一致し、スコア (f.score) が現在の行のスコア (s.score) 以上です。
- WHERE 句は外部クエリにフィルタを適用し、ランク (サブクエリによって決定される) 以下の行のみを選択します。 2.
出力:
このクエリを実行すると、次の結果が返されます:
NAME | SCORE |
---|---|
willy | 2 |
willy | 3 |
zoe | 5 |
zoe | 6 |
このクエリは、上位 2 つを効果的に取得します。各生徒のスコアを表示し、単純な MAX() 集計を使用する場合と比較して、生徒の成績をより包括的に把握できます。
以上がSQL で各グループの上位 2 つのスコアを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

記事では、外部キーを使用してデータベース内の関係を表すことで、ベストプラクティス、データの完全性、および避けるべき一般的な落とし穴に焦点を当てています。

記事では、準備されたステートメント、入力検証、および強力なパスワードポリシーを使用して、SQLインジェクションおよびブルートフォース攻撃に対するMySQLの保護について説明します。(159文字)


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック



