MYSQL row_number() および over() 関数の詳細な使用方法

MYSQL row_number() および over() 関数の詳細な使用方法

構文フォーマット: row_number() over(partition by grouping column order by sorting column desc)

row_number() over() グループ化ソート関数:

row_number() over() 関数を使用する場合、over() でのグループ化と並べ替えは、where、group by、order by よりも後に実行されます。

例1:

表データ:

テーブルTEST_ROW_NUMBER_OVER(を作成
       id varchar(10) が null ではない、
       名前 varchar(10) null,
       年齢 varchar(10) null,
       給与 int null
);
TEST_ROW_NUMBER_OVER t から * を選択します。
 
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(1,'a',10,8000) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(1,'a2',11,6500) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(2,'b',12,13000) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(2,'b2',13,4500) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(3,'c',14,3000) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(3,'c2',15,20000) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(4,'d',16,30000) を挿入します。
TEST_ROW_NUMBER_OVER(id,name,age,salary) に値(5,'d2',17,1800) を挿入します。

一度だけ並べ替え: クエリ結果を並べ替えます (グループ化なし)

id、名前、年齢、給与、行番号()を選択し、給与降順で並べ替えます。rn
TEST_ROW_NUMBER_OVER から t

結果:

さらに並べ替え: IDグループで並べ替え

id、名前、年齢、給与、行番号()を選択し、(idでパーティション分割し、給与の降順で並べ替え)ランク付けします。
TEST_ROW_NUMBER_OVER から t

結果:

再度ソート: 各グループ内のシーケンス番号1のデータを検索します

select * from(select id,name,age,salary,row_number()over(partition by id order by salary desc) rank
TEST_ROW_NUMBER_OVER から t)
ランク <2

結果:

13歳から16歳までのデータを検索するには、給与順に並べ替えます

id、名前、年齢、給与、行番号()を選択し、給与降順で並べ替え、順位付けします。
TEST_ROW_NUMBER_OVER t から、年齢が '13' から '16' の間

結果: 結果のランク番号は、実際にはover(order by salary desc)がwhere age between andの後に実行されることを示しています。

例2:

1. row_number() 関数を使用して番号を付ける。

QT_Customer から email、customerID、ROW_NUMBER() を (order by psd) の行として選択します。

原則: まず psd で並べ替え、並べ替えた後に各データに番号を付けます。

2. 注文を価格の昇順に並べ替え、各レコードを並べ替えます。コードは次のとおりです。

OP_Order から行として DID、customerID、totalPrice、ROW_NUMBER() を (totalPrice で順序付け) 選択します。

3. 各世帯からの注文をすべて数え、各顧客の注文金額に応じて昇順で並べ替え、各顧客の注文に番号を付けます。この方法で、各顧客がいくつ注文したかを知ることができます。

ROW_NUMBER() を選択 (顧客ID でパーティション、合計価格で順序付け)
 OP_Order からの行、顧客 ID、合計価格、DID として

4. 各顧客が最近行った注文の数を数えます。

タブ付き  
(  
ROW_NUMBER() を選択 (顧客ID でパーティション、合計価格で順序付け)
 OP_Order からの行、顧客 ID、合計価格、DID として  
 )  
タブから「注文数」と顧客IDとしてMAX(行)を選択します 
顧客IDでグループ化

5. 各顧客のすべての注文の中で最も小さい購入金額を数え、また、この順序で顧客が行った購入回数も数えます。

アイデア: この操作を実行するには一時テーブルを使用します。

1. まず顧客ごとにグループ化し、次に顧客が注文した時間で並べ替えて番号を付けます。

2. 次に、サブクエリを使用して、各顧客の購入の最小価格を調べます。

3. 各顧客の最低価格に基づいて対応するレコードを検索します。

    タブ付き  
     (  
    ROW_NUMBER() を選択 (顧客 ID によるパーティション、insDT による順序) 
OP_Order からの行、顧客 ID、合計価格、DID として  
    )  
     タブから*を選択  
    totalPriceが   
    (  
    顧客ID別にタブグループからMIN(totalPrice)を選択します。  
     )

6. 顧客による最初の注文を除外します。

アイデア。顧客の最初の注文レコードを照会するには、rows=1 を使用します。

    タブ付き  
    (  
    ROW_NUMBER() を (partition by customerID order by insDT) として行として選択し、* OP_Order から  
    )  
    行数が 1 のタブから * を選択します 
    OP_Orderから*を選択

7. 注意: over などのウィンドウ関数を使用する場合、over でのグループ化と並べ替えは、「where、group by、order by」の実行よりも後に実行されます。

    選択   
    ROW_NUMBER() over(partition by customerID order by insDT) 行として、  
    顧客ID、合計価格、DID  
    OP_Order から insDT>'2011-07-22'

MYSQL row_number() および over() 関数の詳しい使い方については、これで終わりです。MYSQL row_number() および over() 関数の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • PostgreSQL ROW_NUMBER() OVER() の使用方法の説明
  • postgreSQL での row_number() と distinct の使用
  • Postgresql の rank() over、dense_rank()、row_number() の使用法の違い
  • MySQLにおけるrow_numberの実装プロセス
  • SQL Server の row_number 関数の一般的な使用例の詳細
  • 4 つの主要な SQL ランキング関数 ROW_NUMBER、RANK、DENSE_RANK、NTILE の使用方法の紹介
  • SQL ROW_NUMBER() および OVER() メソッドのケーススタディ

<<:  Nginx バージョンのスムーズなアップグレードソリューションの詳細説明

>>:  JS でオブジェクトを作成する 4 つの方法

推薦する

JavaScript Domはカルーセルの原理と例を実装します

カルーセルを作りたい場合、まずその原理を理解する必要があります。画像を右から左にスライドさせるにはど...

ffmpeg 中国語パラメータの説明と使用例

1. ffmpeg がビデオ ファイルをプッシュする場合、オーディオとビデオのエンコード形式は H2...

HTML の div、td、p およびその他のコンテナーでの強制改行と非改行の実装

1. 改行を強制せず、省略記号で終了します。コードをコピーコードは次のとおりです。 <div ...

CSS と JavaScript を使用して管理ダッシュボードのレイアウトを構築するためのサンプル コード

あなたが作成するものこの新しいチュートリアルでは、CSS と JavaScript を使用して、レス...

DockerにRedisコンテナをインストールするための実装手順

目次DockerにRedisをインストールする1. Redisイメージを見つける2. Redisイメ...

MySQLでSELECT文が実行される仕組み

目次1. マクロの観点からMySQLを分析する2. SQL ステートメントを実行するには、どの程度の...

nginx 503 サービスが一時的に利用できない問題を解決する方法

最近、ウェブサイトを更新すると、503 Service Temporarily Unavailabl...

MySQLのexplain型の詳細な説明

導入:多くの場合、さまざまな選択ステートメントを使用して必要なデータを照会した後、多くの人は作業が正...

MySQL で重複行を見つけて削除する方法

目次1. 重複行を見つける方法2. 重複行を削除する方法3. 複数の列で重複を見つける方法4. クエ...

MySQL で explain ステートメントを使用する基本的なチュートリアル

目次1. 概要1. 説明文テスト2. 結果の各列の説明2. ID列の説明1. 環境整備2. expl...

Ubuntuのバックアップ方法(4種類)のまとめ

方法1:リスピンを使用するには、次の手順に従ってください。 sudo add-apt-reposit...

ウェブページ HTML 特殊記号 HTML 特殊文字比較表

特殊記号名前付きエンティティ10進数エンコード特殊記号名前付きエンティティ10進数エンコードアルファ...

MySQLを閉じることができない問題を解決する方法

mysql が閉じない場合の解決策:コンピュータのタスクバーを右クリックしてタスクマネージャーを開き...

WeChatアプレットは固定ヘッダーとリストテーブルコンポーネントを実装します

目次必要:機能ポイントレンダリング実装のアイデア具体的なコード(react\taro3.0)特定のコ...

Vue で円形プログレスバーを実装する例

データ表示は、常にあらゆる職業の人々が求めているものです。特にフロントエンド開発業界では、データを表...