MySQL でソートされたデータに行番号を追加するにはどうすればよいですか?
MySQL でソートされたデータの行番号を追加します
MySQL でソートされたデータを操作する場合、各レコードの行番号を取得すると、提供される情報が強化され、より詳細な分析が容易になります。この記事では、純粋な SQL を使用してこれを実現する方法を検討し、Java またはその他のプログラミング言語での後処理を回避するソリューションを提供します。
データベーステーブル構造
フィールド「orderID」と「itemID」を持つ「orders」という名前の次のテーブルについて考えてみましょう。
mysql> describe orders; +-------------+---------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------------+---------------------+------+-----+---------+----------------+ | orderID | bigint(20) unsigned | NO | PRI | NULL | auto_increment | | itemID | bigint(20) unsigned | NO | | NULL | | +-------------+---------------------+------+-----+---------+----------------+
元のクエリ
最初に、クエリを使用して各 itemID の注文数を取得します:
SELECT itemID, COUNT(*) as ordercount FROM orders GROUP BY itemID ORDER BY ordercount DESC;
行番号を追加
行番号を追加するには、次のようにクエリを変更します:
SET @rank=0; SELECT @rank:=@rank+1 AS rank, itemID, COUNT(*) as ordercount FROM orders GROUP BY itemID ORDER BY ordercount DESC; SELECT @rank;
説明
- SET @rank=0;: これにより、ユーザー定義変数 @rank が 0 に初期化され、行番号のカウンターとして機能します。
- SELECT @rank:=@rank 1 AS Rank, itemID, COUNT(*) as ordercount: クエリのこの部分は次のことを行います:
- 行ごとに @rank を 1 ずつインクリメントし、結果の「ランク」列に新しい値を割り当てます。
- 元のクエリの「itemID」列と「ordercount」列を保持します。
- ORDER BY ordercount DESC: この句は、行が「ordercount」フィールドに基づいて降順でソートされることを保証します。
- SELECT @rank: 最後の SELECT ステートメントは、結果セット内の行の合計数を表す @rank の最終値を取得します。
結果の改善
変更したクエリを実行すると、次の拡張された結果が得られます:
<code>+------+--------+------------+ | rank | itemID | ordercount | +------+--------+------------+ | 1 | 388 | 3 | | 2 | 234 | 2 | | 3 | 3432 | 1 | | 4 | 693 | 1 | | 5 | 3459 | 1 | +------+--------+------------+</code>
ご覧のとおり、各行には、並べ替えられた結果セット内での位置を示す追加の「ランク」列が追加されました。
以上がMySQL でソートされたデータに行番号を追加するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
