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
Freigeben: 2025-01-22 00:08:11
Original
455 Leute haben es durchsucht

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren
  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>
Nach dem Login kopieren
  1. Führen Sie eine weitere SELECT-Anweisung aus, um die endgültige Zeilenanzahl abzurufen:
<code class="language-sql">SELECT @rank;</code>
Nach dem Login kopieren

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>
Nach dem Login kopieren

Ausgabe:

<code>1 | 388 | 3
2 | 234 | 2
3 | 693 | 1
4 | 3432 | 1
5 | 3459 | 1</code>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage