gpt4 book ai didi

php - 如何在 PHP 的 foreach 循环中优化大型 mySQL?

转载 作者:行者123 更新时间:2023-11-29 07:47:35 25 4
gpt4 key购买 nike

我有一个函数,可以获取用户详细信息并返回一个关联数组,该数组由每个用户及其相关数据的数组组成。我的函数可以工作,只是当它必须从 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com