Menyelesaikan masalah Isu Pemilihan FLOAT MySQL
Apabila cuba mendapatkan semula baris daripada jadual MySQL berdasarkan nilai apungan, isu biasa timbul apabila nilai yang sepadan mengembalikan sifar baris. Masalah ini boleh nyata apabila terapung dalam jadual dan pertanyaan mempunyai ketepatan yang berbeza.
Sebagai contoh, pertimbangkan pertanyaan berikut:
SELECT * FROM `table` WHERE `ident`='ident23' AND `price`='101.31';
Walaupun jadual mengandungi baris dengan ident= 'ident23' dan price='101.31', pertanyaan mungkin tidak sepadan dengannya kerana ketepatan yang berbeza. Untuk menangani perkara ini, anda boleh menghantar lajur harga kepada jenis PERPULUHAN:
SELECT * FROM table WHERE CAST(price AS DECIMAL) = CAST(101.31 AS DECIMAL);
Ini akan memastikan kedua-dua nilai dibandingkan dengan ketepatan yang sama, membolehkan pertanyaan mendapatkan semula baris yang betul.
Sebagai alternatif, anda boleh mempertimbangkan untuk menukar lajur harga kepada jenis PERPULUHAN secara kekal. DECIMAL secara amnya ialah jenis data pilihan untuk mengendalikan nilai monetari kerana ketepatannya yang lebih tinggi berbanding dengan FLOAT.
Atas ialah kandungan terperinci Mengapa Pertanyaan MySQL Saya Tidak Menemui Nilai Terapung Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!