Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Melaksanakan Kedudukan dalam MySQL Tanpa Fungsi RANK Asli?
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!