Heim >Datenbank >MySQL-Tutorial >Wie füge ich Zeilennummern zu sortierten SELECT-Ergebnissen in MySQL hinzu?

Wie füge ich Zeilennummern zu sortierten SELECT-Ergebnissen in MySQL hinzu?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-22 00:08:11414Durchsuche

How to Add Row Numbers to Sorted SELECT Results in MySQL?

MySQL: Zeilennummer aus sortierten SELECT-Ergebnissen abrufen

Frage:

Wie erhalte ich die Zeilennummer des sortierten Elements in der SELECT-Anweisung von MySQL?

Hintergrund:

Stellen Sie sich eine Tabelle mit dem Namen „Bestellungen“ vor, die die Spalten „orderID“ und „itemID“ enthält. Die unten gezeigte Abfrage berechnet die Bestellmenge nach „itemID“:

<code class="language-sql">SELECT itemID, COUNT(*) as ordercount
FROM orders
GROUP BY itemID
ORDER BY ordercount DESC;</code>

Diese Abfrage gibt die Anzahl der Elemente zurück, jedoch nicht die Zeilennummer.

Lösung:

Um die Zeilennummer abzurufen, verwenden Sie die folgende Technik:

  1. Initialisieren Sie eine Variable, um die aktuelle Zeilennummer zu speichern:
<code class="language-sql">SET @rank=0;</code>
  1. Ändern Sie die ursprüngliche Abfrage, um Variablen zum Zuweisen von Zeilennummern zu verwenden:
<code class="language-sql">SELECT @rank:=@rank+1 AS rank, itemID, COUNT(*) as ordercount
FROM orders
GROUP BY itemID
ORDER BY ordercount DESC;</code>
  1. Führen Sie eine weitere SELECT-Anweisung aus, um die endgültige Zeilenanzahl abzurufen:
<code class="language-sql">SELECT @rank;</code>

Beispiel:

Die folgende Abfrage gibt die Zeilennummer und die Elementanzahl zurück:

<code class="language-sql">SET @rank=0;
SELECT @rank:=@rank+1 AS rank, itemID, COUNT(*) as ordercount
  FROM orders
  GROUP BY itemID
  ORDER BY ordercount DESC;
SELECT @rank;</code>

Ausgabe:

<code>1 | 388 | 3
2 | 234 | 2
3 | 693 | 1
4 | 3432 | 1
5 | 3459 | 1</code>

Die endgültige Zeilenanzahl beträgt 5.

Das obige ist der detaillierte Inhalt vonWie füge ich Zeilennummern zu sortierten SELECT-Ergebnissen in MySQL hinzu?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn