注意:我是PHP初学者,这就是为什么下面的代码可能很糟糕。
你好。我现在正在使用这段代码来选择 9 个唯一的随机行,它工作正常。
$quCountRows = $database->query("SELECT * FROM approved")->rowCount();
$arrRandomPictures = array();
while (count($arrRandomPictures) < 9) {
$randNumber = mt_rand(1, $quCountRows);
if (!in_array($randNumber, $arrRandomPictures)) {
$arrRandomPictures[] = $randNumber;
}
}
$quRandomPicture1 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[0]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture2 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[1]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture3 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[2]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture4 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[3]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture5 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[4]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture6 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[5]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture7 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[6]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture8 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[7]."'")->fetch(PDO::FETCH_ASSOC);
$quRandomPicture9 = $database->query("SELECT picName,picType FROM approved WHERE id='".$arrRandomPictures[8]."'")->fetch(PDO::FETCH_ASSOC);
虽然它可能有效,但我很确定可以用更少的查询获得相同的结果。这有望使页面加载更快。
有什么建议吗?
这是更好的代码。感谢琥珀!
$quCountRows = $database->query("SELECT * FROM approved")->rowCount();
$arrRandomPictures = array();
while (count($arrRandomPictures) < 9) {
$randNumber = mt_rand(1, $quCountRows);
if (!in_array($randNumber, $arrRandomPictures)) {
$arrRandomPictures[] = $randNumber;
}
}
$quRandomPicture = $database->query("SELECT picName,picType FROM approved WHERE id IN (".implode(', ', $arrRandomPictures).")")->fetchAll(PDO::FETCH_ASSOC);
使用 in
而不是 ==
并传递 ID 列表。这样,您可以从一个查询而不是 9 个查询中获取所有结果。
您可以按随机数排序,每次都能获得其他结果。这样,您只需要一个查询!
SELECT picName, picType FROM approved ORDER BY rand() LIMIT 0, 9;