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
Lepaskan: 2025-01-24 05:06:09
asal
420 orang telah melayarinya

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:

SELECT    first_name,
          age,
          gender,
          @curRank := @curRank + 1 AS rank
FROM      person p, (SELECT @curRank := 0) r
ORDER BY  age;
Salin selepas log masuk
Salin selepas log masuk

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:

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');
Salin selepas log masuk

Lakukan pertanyaan:

SELECT    first_name,
          age,
          gender,
          @curRank := @curRank + 1 AS rank
FROM      person p, (SELECT @curRank := 0) r
ORDER BY  age;
Salin selepas log masuk
Salin selepas log masuk

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>
Salin selepas log masuk

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 Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan