Rumah >pangkalan data >tutorial mysql >Bagaimana saya boleh meniru fungsi Row_Number () SQL Server di MySQL?
Setara ROW_NUMBER() MySQL: Perbandingan
FungsiSQL Server ROW_NUMBER()
memberikan nombor jujukan unik kepada baris, memudahkan kedudukan baris dan pengambilan data. MySQL, bagaimanapun, tidak mempunyai persamaan langsung. Mari kita terokai cara untuk mencapai hasil yang serupa.
Penyelesaian untuk Versi MySQL Lama
Untuk versi MySQL sebelum 8.0, kami boleh menggunakan pembolehubah yang ditentukan pengguna untuk mensimulasikan ROW_NUMBER()
:
<code class="language-sql">SELECT t.*, @rownum := @rownum + 1 AS rank FROM YOUR_TABLE t, (SELECT @rownum := 0) r;</code>
Ini memulakan @rownum
kepada 0 dan menambahnya untuk setiap baris, mewujudkan kedudukan berjujukan.
Meniru PARTITION BY dan ORDER BY
SQL Server ROW_NUMBER()
sering menggunakan klausa PARTITION BY
dan ORDER BY
. Meniru ini dalam MySQL yang lebih lama memerlukan pengendalian pembolehubah yang lebih kompleks, menetapkan semula pembilang untuk setiap partition. Pendekatan ini menjadi kurang cekap dan lebih terdedah kepada ralat dengan berbilang lajur pembahagian.
Penyelesaian Elegan: Fungsi Tetingkap MySQL 8.0
MySQL 8.0 dan versi yang lebih baru menawarkan fungsi tetingkap, termasuk RANK()
, menyediakan alternatif yang lebih bersih dan lebih cekap:
<code class="language-sql">SELECT col1, col2, RANK() OVER (PARTITION BY col1, col2 ORDER BY col3 DESC) AS intRow FROM Table1;</code>
Ini secara langsung mencerminkan kefungsian ROW_NUMBER()
dengan PARTITION BY
dan ORDER BY
, menawarkan penyelesaian yang dipertingkatkan dengan ketara untuk senario kedudukan yang kompleks. Kaedah ini disyorkan untuk MySQL 8.0 dan lebih baru.
Atas ialah kandungan terperinci Bagaimana saya boleh meniru fungsi Row_Number () SQL Server di MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!