重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php数据库内存 php内存占用

如何解决PHP查询大量数据内存耗尽的问题

这个问题在PHP的官方网站上叫缓冲查询和非缓冲查询(Buffered and Unbuffered queries)。PHP的查询缺省模式是缓冲模式。也就是说,查询数据结果会一次全部提取到内存里供PHP程序处理。这样给了PHP程序额外的功能,比如说,计算行数,将指针指向某一行等。更重要的是程序可以对数据集反复进行二次查询和过滤等操作。但这种缓冲查询模式的缺陷就是消耗内存,也就是用空间换速度。

集美ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联建站的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18982081108(备注:SSL证书合作)期待与您的合作!

相对的,另外一种PHP查询模式是非缓冲查询,数据库服务器会一条一条的返回数据,而不是一次全部返回,这样的结果就是PHP程序消耗较少的内存,但却增加了数据库服务器的压力,因为数据库会一直等待PHP来取数据,一直到数据全部取完。

很显然,缓冲查询模式适用于小数据量查询,而非缓冲查询适应于大数据量查询。

如何解决PHP里大量数据循环时内存耗尽的问题

?php

mysql_connect("localhost", "mysql_user", "mysql_password") or

die("Could not connect: " . mysql_error());//连接你的数据库

mysql_select_db("mydb");//选择你的数据库

$result = mysql_query("SELECT `name` FROM data_boy WHERE `id`='2' LIMIT 0, 60");//执行SQL查询语句,搜索出60条数据

while ($row = mysql_fetch_array($result)) {

echo "姓名:".$row[name]."br";

/*补充一句,此处也可以是:

echo "姓名:".$row[0]."br";此处"mysql_fetch_array"默认返回的既有 关联数组(字段作为键名),也有数字索引数组*/

}

mysql_free_result($result);//释放结果

如何获知PHP程序占用多少内存memory

想要知道编写的 PHP 脚本需要占用多少内存么?很简单,直接使用 PHP 查看当前分配给 PHP 脚本的内存的函数 memory_get_usage() 就可以了。

下面是使用示例:

?php

echo memory_get_usage(), 'br /'; // 313864

$tmp = str_repeat('', 4000);

echo memory_get_usage(), 'br /'; // 406048

unset($tmp);

echo memory_get_usage(); // 313952

?

上面的程序后面的注释代表了它们的输出(单位为 byte(s)),也就是当时 PHP 脚本使用的内存(不含 memory_get_usage() 函数本身占用的内存)。

由上面的例子可以看出,要想减少内存的占用,可以使用 PHP unset() 函数把不再需要使用的变量删除。类似的还有:PHP mysql_free_result() 函数,可以清空不再需要的查询数据库得到的结果集,这样也能得到更多可用内存。

PHP memory_get_usage() 函数还可以有个参数,$real_usage,其值为布尔值。默认为

FALSE,表示得到的内存使用量不包括该函数(PHP 内存管理器)占用的内存;当设置为 TRUE 时,得到的内存为不包括该函数(PHP

内存管理器)占用的内存。

所以在实际编程中,可以用 memory_get_usage() 函数比较各个方法占用内存的高低,来选择使用哪种占用内存小的方法。

贴个使用函数:

if (!function_exists('memory_get_usage'))

{

/**

+----------------------------------------------------------

* 取得内存使用情况

+----------------------------------------------------------

* @return integer

+----------------------------------------------------------

*/

function memory_get_usage()

{

$pid = getmypid();

if (IS_WIN)

{

exec('tasklist /FI "PID eq ' . $pid . '" /FO LIST', $output);

return preg_replace('/[^0-9]/', '', $output[5]) * 1024;

}

else

{

exec("ps -eo%mem,rss,pid | grep $pid", $output);

$output = explode(" ", $output[0]);

return $output[1] * 1024;

}

}

}

再来个函数使用例子:

?php

//memory_get_usage();

$m1 = memory_get_usage();

echo 'br / m1:',$m1;//58096

$a = 'hello';

$b = str_repeat($a,1000);

$m2 = memory_get_usage();

echo 'br / m2:',$m2;//63424

unset($b);

$m3 = memory_get_usage();

echo 'br / m3:',$m3;//58456

?

如何解决PHP向数据库大量插入数据时,占用内存不断上升的问题

如何解决PHP向数据库大量插入数据时,占用内存不断上升的问题

?php

mysql_connect("localhost", "mysql_user", "mysql_password") or

die("Could not connect: " . mysql_error());//连接你的数据库

mysql_select_db("mydb");//选择你的数据库

$result = mysql_query("SELECT `name` FROM data_boy WHERE `id`='2' LIMIT 0, 60");//执行SQL查询语句,搜索出60条数据

while ($row = mysql_fetch_array($result)) {

echo "姓名:".$row[name]."br";

/*补充一句,此处也可以是:

echo "姓名:".$row[0]."br";此处"mysql_fetch_array"默认返回的既有 关联数组(字段作为键名),也有数字索引数组*/


分享标题:php数据库内存 php内存占用
标题网址:http://cqcxhl.com/article/hpegcj.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP