作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个函数,可以获取用户详细信息并返回一个关联数组,该数组由每个用户及其相关数据的数组组成。我的函数可以工作,只是当它必须从 mySQL 获取大量行时它不能正常工作。
function function_name($DB, $id)
{
//Prepare, bind and execute statements
//Returns one value or an array
}
function main_function($DB, $id_list)
{
foreach($id_list as $user_id)
{
//Calls function_name
$data = function_name($DB, $user_id);
}
//Returns a nested associative array
}
有人告诉我,在我的例子中,我应该将绑定(bind)参数语句移到 foreach 循环之外,但我已经尝试过了,但我不断收到错误“MySQL 已消失”消息。当我可能一次查询 10,0000 个 id 时,如何优化 mysql 的查询?
详细说明请引用下面的代码片段。
function getUserEvent($DB_3308, $user_id)
{
$user_event = array ();
$sql_get_user_event = "SELECT * FROM user_event WHERE user_id = ?";
$statement_user_event = $DB_PUMA_3306->link->prepare ( $sql_get_user_event);
$statement_user_event ->bind_param ( "s", $user_id );
$statement_user_event ->execute ();
if ($rs_user_event = $statement_user_event->get_result ())
{
while ( $row = $rs_user_event->fetch_assoc () )
{
$user_event [] = $row;
}
}
return $user_event;
}
function getUserDetails($DB_3306, $DB_3308, $user_list)
{
$user_details = array ();
foreach ( $user_list as $user_id )
{
$temp = array ();
$user_personal = null;
$user_event = null;
$user_personal = getUserContact ( $DB_3306, $user_id );
$user_event = getUserEvent( $DB_3308, $userid );
$temp ['user_id'] = $user_id;
$temp ['full_name'] = $user_personal ['full_name'];
$temp ['tel_no'] = $user_personal ['tel_no'];
$temp ['email'] = $user_personal ['email'];
$temp ['events'] = $user_event ;
$user_details [] = $temp;
}
return $user_details;
}
最佳答案
为什么不能先在数组中获取 50 或 100 个用户 ID,然后再从数据库中获取并批量获取以减少更多查询负载?
$implodedUserIDs = implode(',', $userIDs);
$query = "SELECT * FROM user_event WHERE user_id IN ($implodedUserIDs)";
这会减少一些负载。您也可以在每次负荷时给予一些 sleep 。只是尝试尽可能优化您的代码。 :)
关于php - 如何在 PHP 的 foreach 循环中优化大型 mySQL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27310758/
我是一名优秀的程序员,十分优秀!