我收到此错误。我使用类文件,函数文件,然后使用视图文件。致命错误:允许内存耗尽
public function adminSearchFullName($admin_firstname,$admin_lastname){
$adminsearchresultsfullname = array();
try {
$db = database::databaseConnect();
$stmt = $db->prepare('SELECT * FROM personalinfo WHERE firstname like ? AND lastname like ? AND deleted = 0');
$stmt->execute(array('%' . $admin_firstname . '%', '%' . $admin_lastname . '%'));
$adminsearchresultsfullname = $stmt->fetchAll(PDO::FETCH_OBJ);
if($stmt->rowCount() < 1){
$adminsearchresultsfullname = null;
}
$db = null;
}
catch (PDOException $e){
$adminsearchresultsfullname = null;
}
return $adminsearchresultsfullname;
}
我的功能如下:
function adminSearchFullName($admin_firstname,$admin_lastname){
return $adminsearchresultsfullname = adminSearchFullName($admin_firstname,$admin_lastname);
}
最后我的视图页面如下:
if(!empty ($admin_firstname) && !empty($admin_lastname)){
//Query and display contact details based on first and last names.
$adminsearchresultsfullname = adminSearchFullName($admin_firstname,$admin_lastname);
if ($adminsearchresultsfullname != null){
?>
<a href="index.php">Home</a> | <a href="adduser.php">Add User</a> | <a href="viewusers.php">View Users</a> |<a href="addcontact.php">Add Contact</a> | <a href="viewcontacts.php">View Contacts</a> | <a href="searchcontact.php">Search Contact</a><br /><hr />
<p>Click on the name to see details of the contact.</p>
<table cellpadding="5">
<tr>
<td>
<b>Search result</b>
</td>
</tr>
<?php
foreach($adminsearchresultsfullname as $key => $adminfoundfullname){
$admin_id_fullname = $adminfoundfullname->id;
$admin_found_fullname_firstname = $adminfoundfullname->firstname;
$admin_found_fullname_lastname = $adminfoundfullname->lastname;
?>
<tr>
<td>
<a href="contactdetails.php?id=<?php echo $admin_id_fullname; ?>"><?php echo $admin_found_fullname_firstname . ' ' . $admin_found_fullname_lastname; ?></a>
</td>
</tr>
<?php
}?>
</table>
<?php }
}else{
echo 'No record found. Please <a href="searchcontact.php"> return</a> and try a different name.';
}
其余和所有其他只查找名字和姓氏的函数都会产生罚款。
答案 0 :(得分:1)
不必增加内存限制,而是必须减少脚本处理的数据量。这就是数据库的用途。让数据库完成所有工作,然后只返回特定页面上所需的数据。它很少超过100千字节 - 否则pagge将太重而无法通过浏览器加载。
然而,似乎您的问题仅仅因为意外递归而得到了解决,而您已经解决了问题。