Bagaimanakah saya boleh menyusun nombor versi MySQL dengan betul?

Patricia Arquette
Lepaskan: 2024-11-07 19:33:02
asal
228 orang telah melayarinya

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

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

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!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan