アイテムがソートされている場合、selectステートメントを実行して行番号を取得できますか?
私はこのようなテーブルを持っています:
mysql> describe orders;
+-------------+---------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------------+---------------------+------+-----+---------+----------------+
| orderID | bigint(20) unsigned | NO | PRI | NULL | auto_increment |
| itemID | bigint(20) unsigned | NO | | NULL | |
+-------------+---------------------+------+-----+---------+----------------+
次に、このクエリを実行して、ID別の注文数を取得できます。
SELECT itemID, COUNT(*) as ordercount
FROM orders
GROUP BY itemID ORDER BY ordercount DESC;
これによりitemID
、次のように表のそれぞれの数がわかります。
+--------+------------+
| itemID | ordercount |
+--------+------------+
| 388 | 3 |
| 234 | 2 |
| 3432 | 1 |
| 693 | 1 |
| 3459 | 1 |
+--------+------------+
行番号も取得したいので、それitemID=388
が最初の行であるか、234
2番目であるかなどがわかります(基本的に、生のカウントだけでなく、注文のランキングです)。結果セットが返されたときにJavaでこれを実行できることはわかっていますが、純粋にSQLで処理する方法があるかどうか疑問に思っていました。
更新
ランクを設定すると、結果セットにランクが追加されますが、正しく順序付けされていません。
mysql> SET @rank=0;
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT @rank:=@rank+1 AS rank, itemID, COUNT(*) as ordercount
-> FROM orders
-> GROUP BY itemID ORDER BY rank DESC;
+------+--------+------------+
| rank | itemID | ordercount |
+------+--------+------------+
| 5 | 3459 | 1 |
| 4 | 234 | 2 |
| 3 | 693 | 1 |
| 2 | 3432 | 1 |
| 1 | 388 | 3 |
+------+--------+------------+
5 rows in set (0.00 sec)
ORDER BY rank ASC
注文する場合は、(ASCの降順でのランクによる順序付け)を使用します。それはあなたの言っていることだと思いますが、適切に注文