PHP的-比这更快,更有效的代码? (抓取9个唯一的随机行)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP的-比这更快,更有效的代码? (抓取9个唯一的随机行),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2254字,纯文字阅读大概需要4分钟。
内容图文
![PHP的-比这更快,更有效的代码? (抓取9个唯一的随机行)](/upload/InfoBanner/zyjiaocheng/675/f346ff5e1f8d4c67818de04e1d7b0146.jpg)
注意:我是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中获取所有结果.
内容总结
以上是互联网集市为您收集整理的PHP的-比这更快,更有效的代码? (抓取9个唯一的随机行)全部内容,希望文章能够帮你解决PHP的-比这更快,更有效的代码? (抓取9个唯一的随机行)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。