Masalah:
Anda mempunyai jadual MySQL dengan dua lajur, min_value dan max_value. Anda ingin mendapatkan semula nilai rawak antara dua nilai ini.
Fungsi RAND() dalam MySQL tidak menyediakan fungsi ini secara langsung. Penyelesaian terdekat ialah RAND() * (maks-min) min, tetapi ia menghasilkan apungan, bukan integer. Untuk mendapatkan integer, anda memerlukan fungsi lain seperti ROUND() untuk memotong bahagian perpuluhan, tetapi itu tidak praktikal.
Penyelesaian:
Kaedah yang paling berkesan dalam MySQL adalah menggunakan ungkapan asal ROUND((RAND() * (maks-min)) min). Ini adalah pendekatan terbaik dalam bahasa pengaturcaraan lain juga, seperti ActionScript, JavaScript dan Python.
Perbandingan Prestasi antara PHP dan MySQL:
Jika anda tidak pasti sama ada untuk menjana nilai rawak dalam PHP atau MySQL, pertimbangkan bilangan baris yang terlibat. Jika set data adalah besar, adalah lebih cekap untuk menggunakan MySQL.
Untuk menunjukkan perbezaan prestasi, mari kita bandingkan dua senario dengan 100,000 lelaran:
Walau bagaimanapun, jika anda mendapatkan semula lajur tambahan bersama-sama dengan nilai rawak, PHP menjadi lebih cekap:
Kesimpulannya, untuk prestasi optimum, gunakan MySQL jika hanya nilai rawak diperlukan, dan gunakan PHP jika lajur tambahan perlu dikembalikan.
Atas ialah kandungan terperinci Berikut ialah beberapa pilihan tajuk, memfokuskan pada aspek soalan: Pilihan 1 (Terus & Jelas): * Bagaimana untuk Menjana Integer Rawak Dalam Julat dalam MySQL? Pilihan 2 (Fokus pada Masalah & Penyelesaian): *. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!