Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Melaksanakan Kedudukan dalam MySQL Tanpa Fungsi RANK Asli?

Bagaimanakah Saya Boleh Melaksanakan Kedudukan dalam MySQL Tanpa Fungsi RANK Asli?

Linda Hamilton
Linda Hamiltonasal
2025-01-24 05:06:09350semak imbas

How Can I Implement Ranking in MySQL Without a Native RANK Function?

Melaksanakan ranking dalam MySQL: alternatif untuk menggunakan pembolehubah

MySQL sendiri tidak menyediakan fungsi RANK yang setanding dengan pertanyaan SQL standard ANSI. Walau bagaimanapun, terdapat alternatif untuk menggunakan pembolehubah untuk mencapai fungsi yang serupa.

Berikut ialah contoh pertanyaan MySQL:

<code class="language-sql">SELECT    first_name,
          age,
          gender,
          @curRank := @curRank + 1 AS rank
FROM      person p, (SELECT @curRank := 0) r
ORDER BY  age;</code>

Pertanyaan ini menggunakan pembolehubah kedudukan @curRank, yang dimulakan kepada sifar menggunakan subkueri (SELECT @curRank := 0). Apabila setiap baris jadual person diproses, pembolehubah @curRank ditambah dengan 1, mewujudkan mekanisme kedudukan berdasarkan kriteria pengisihan yang ditentukan (dalam kes ini, umur).

Untuk menggambarkan ini, mari gunakan kaedah ini pada contoh person jadual:

<code class="language-sql">CREATE TABLE person (id int, first_name varchar(20), age int, gender char(1));

INSERT INTO person VALUES (1, 'Bob', 25, 'M');
INSERT INTO person VALUES (2, 'Jane', 20, 'F');
INSERT INTO person VALUES (3, 'Jack', 30, 'M');
INSERT INTO person VALUES (4, 'Bill', 32, 'M');
INSERT INTO person VALUES (5, 'Nick', 22, 'M');
INSERT INTO person VALUES (6, 'Kathy', 18, 'F');
INSERT INTO person VALUES (7, 'Steve', 36, 'M');
INSERT INTO person VALUES (8, 'Anne', 25, 'F');</code>

Lakukan pertanyaan:

<code class="language-sql">SELECT    first_name,
          age,
          gender,
          @curRank := @curRank + 1 AS rank
FROM      person p, (SELECT @curRank := 0) r
ORDER BY  age;</code>

akan menghasilkan keputusan berikut:

<code>+------------+------+--------+------+
| first_name | age  | gender | rank |
+------------+------+--------+------+
| Kathy      |   18 | F      |    1 |
| Jane       |   20 | F      |    2 |
| Nick       |   22 | M      |    3 |
| Bob        |   25 | M      |    4 |
| Anne       |   25 | F      |    5 |
| Jack       |   30 | M      |    6 |
| Bill       |   32 | M      |    7 |
| Steve      |   36 | M      |    8 |
+------------+------+--------+------+
8 rows in set (0.02 sec)</code>

Nampaknya, pertanyaan ini berjaya memberikan kedudukan kepada individu dalam setiap partition jantina, serupa dengan hasil yang dijangkakan bagi pertanyaan SQL standard ANSI. Teknik ini menyediakan penyelesaian praktikal apabila MySQL tidak mempunyai fungsi RANK khusus.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Kedudukan dalam MySQL Tanpa Fungsi RANK Asli?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn