Merawakkan Pemilihan Pangkalan Data Merentas Berbilang Kategori
Cabaran yang dikemukakan di sini adalah untuk mendapatkan semula satu rekod rawak daripada setiap kategori dalam pangkalan data. Jadual Item menempatkan rekod ini, setiap satunya diberikan kepada kategori yang ditentukan oleh jadual Kategori yang sepadan.
Untuk mendekati tugas ini, seseorang boleh memanfaatkan rawak sedia ada MySQL dengan fungsi RAND() dan klausa LIMIT 1. Walau bagaimanapun, aspek unik di sini ialah keperluan untuk memilih rekod rawak untuk setiap kategori yang berbeza.
Pertanyaan berikut dengan elegan menangani cabaran ini:
SELECT * FROM ( SELECT c.id AS cid, c.category, i.id AS iid, i.name FROM categories c INNER JOIN items i ON c.id = i.category ORDER BY RAND() ) AS shuffled_items GROUP BY cid
Struktur pertanyaan ini membolehkan mendapatkan semula satu rekod rawak daripada setiap kategori:
Walaupun pendekatan ini mungkin tidak mempunyai kelajuan yang luar biasa, pendekatan ini berkesan menangani cabaran pemilihan rekod rawak merentas berbilang kategori. Cadangan alternatif untuk pengoptimuman adalah dialu-alukan, meningkatkan lagi kegunaan pertanyaan ini.
Atas ialah kandungan terperinci Bagaimana untuk Memilih Satu Rekod Rawak daripada Setiap Kategori dalam Pangkalan Data MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!