Rumah >pangkalan data >tutorial mysql >Bagaimanakah saya boleh menyusun nombor versi MySQL dengan betul?

Bagaimanakah saya boleh menyusun nombor versi MySQL dengan betul?

Patricia Arquette
Patricia Arquetteasal
2024-11-07 19:33:02297semak imbas

How Can I Sort MySQL Version Numbers Correctly?

Pengisihan Nombor Versi MySQL

Masalah:

Rutin pengisihan MySQL mungkin tidak menyediakan susunan isihan yang diingini untuk nombor versi yang disimpan sebagai varbinari(300). Isih perlu mengambil kira sehingga 20 digit dan menghasilkan keputusan seperti:

1.1.2
1.2.3.4
2.2
3.2.1.4.2
3.2.14
4
9.1

Penyelesaian:

Gunakan fungsi INET_ATON dengan pertanyaan berikut:

SELECT version_number FROM table ORDER BY INET_ATON(SUBSTRING_INDEX(CONCAT(version_number,'.0.0.0'),'.',4))

Teknik ini memanfaatkan keupayaan INET_ATON untuk menukar alamat IP kepada integer. Dengan menambahkan .0.0.0 pada nombor versi dan mengekstrak hanya empat komponen pertama menggunakan SUBSTRING_INDEX, kami menterjemah nombor versi ke dalam perwakilan integer yang setanding.

Pertimbangan Tambahan:

  • Pendekatan ini tidak memanfaatkan pengindeksan, kerana ia beroperasi pada fungsi lajur dan bukannya lajur itu sendiri. Isih mungkin agak perlahan dalam sesetengah kes.
  • Untuk nombor versi yang lebih besar, pertimbangkan untuk menggunakan lajur berasingan untuk setiap bahagian nombor versi.

Atas ialah kandungan terperinci Bagaimanakah saya boleh menyusun nombor versi MySQL dengan betul?. 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