Pemilihan Rawak dengan Keputusan Berwajaran dalam MySQL
Isu ini melibatkan pemilihan entri rawak daripada jadual MySQL di mana baris ditimbang berdasarkan " lajur Pengganda". Pendekatan konvensional menggunakan RAND() tidak mengambil kira pemberat ini.
Untuk menangani perkara ini, pengguna mencadangkan pendekatan yang melibatkan ORDER BY -LOG(1.0 - RAND()) / Multiplier. Formula ini melaraskan proses rawak dengan berkesan untuk memberikan baris berwajaran kebarangkalian yang lebih tinggi untuk dipilih.
Formula mengira nilai yang mewakili "rawak" untuk setiap baris, dengan nilai yang lebih rendah menunjukkan kebarangkalian yang lebih tinggi. Dengan membahagikan nilai ini dengan "Pendarab", baris dengan pengganda yang lebih tinggi secara berkesan diberikan "rawak" yang lebih rendah dan dengan itu peluang yang lebih tinggi untuk dipilih.
Kelemahan kaedah ini ialah tidak mungkin untuk melumpuhkan satu baris dengan menetapkan pengganda kepada 0, kerana ia akan menghasilkan pembahagian dengan sifar. Walau bagaimanapun, had ini boleh diatasi dengan menapis baris dengan WHERE Multiplier > 0 untuk mengecualikan yang mempunyai pengganda sifar.
Atas ialah kandungan terperinci Bagaimana untuk memilih baris rawak berwajaran dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!