失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 如何解决PHP使用mysql_query查询超大结果集超内存问题【PHP】

如何解决PHP使用mysql_query查询超大结果集超内存问题【PHP】

时间:2022-10-16 19:58:21

相关推荐

如何解决PHP使用mysql_query查询超大结果集超内存问题【PHP】

后端开发|php教程

mysql_query结果集,mysql结果集

后端开发-php教程

再使用mysql_query查询超大结果集的时候会出现超出内存限制的致命错误,这是因为mysql_query采用的是查询全部结果然后把结果集全部缓存到内存中的方式。

幕课平台源码,vscode设置中文语言,ubuntu配置socks,tomcat修改http,sqlite中排序的实例,服务器防爬虫软件下载,ldap 安装 php,常德seo优化收费,最新球球带点网站源码,哪里有平台可以取网页源码,唱片管理模板lzw

mysql的查询还提供了另外一种查询方式,函数名为mysql_unbuffered_query,这个函数采用的是查出结果后立即操作结果集,并不会把结果集缓存到内存中,这样就避免了超出内存的情况发生。但是使用这个方法的代价就是不能再查询的时候使用获取总行之类的方法,因为这种方法是便查询边返回结果。同时在使用该方法的时候不能在同一数据库链接上执行其他的操作,想要执行其他操作的时候必须先终止当前操作,释放所有未缓存的sql查询所产生的结果行,或者重新实例化一个数据库连接,使用新链接进行其他操作。

惠多网java商城源码,sdk怎么导入vscode,ubuntu节电管理,tomcat线程分类,sqlite可以存中文吗,数据挖掘就是通过爬虫获取数据,php gpio,岳阳怎样seo优化,蚂蚁影院电影网站源码,为什么网页自动下拉,h5框架模板lzw

以下是使用缓存和不使用缓存的对比(所查询的表中有1000多万行数据):

图片翻页源码,vscode 主题排行,ubuntu镜像文件制作,测试 tomcat,sqlite测试性能,怎么做dns服务器,photoshop纹理插件,前端框架处理视频,python 反爬虫机制,php跨年,seo培训学校排名,网站爬虫php源代码,云免流网站网页源码,app下载模板,注册页面html 图片,excel库存管理系统,dibr程序lzw

function selecttest(){try {$pdo = new PDO("mysql:host=localhost;dbname=test", oot, 123456);// 不使用缓存结果集方式// $pdo->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);$sth = $pdo->prepare(select * from test);$sth->execute();echo 最初占用内存大小: . memory_get_usage() . "\n";$i = 0;while ($result = $sth->fetch(PDO::FETCH_ASSOC)) {$i += 1;if ($i > 10) {break;}sleep(1);print_r($result);echo 占用内存大小: . memory_get_usage() . "\n";}} catch (Exception $e) {echo $e->getMessage();}}

上面使用到的是缓存所有结果集的方式,运行该函数时将会报超内存的错误,如下所示:

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 204800000 bytes) in E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php on line 57

Call Stack:

0.0005 135392 1. {main}() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:0

0.0005 135568 2. test->selecttest() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:86

0.0055 142528 3. PDOStatement->execute() E:\ProgramDevelopment\RuntimeEnvironment\xampp\htdocs\test\test.php:57

在执行$sth->execute();时超出内存限制;

将// $pdo->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, false);这行的注释去掉后将使用不缓存结果集的方式,运行该函数将输出以下内容:

最初占用内存大小:144808

Array([id] => 1[a] => v[b] => w[c] => i)

占用内存大小:145544

Array([id] => 2[a] => b[b] => l[c] => q)

占用内存大小:145544

Array([id] => 3[a] => m[b] => p[c] => h)

占用内存大小:145536

Array([id] => 4[a] => j[b] => i[c] => b)

占用内存大小:145536

Array([id] => 5[a] => q[b] => g[c] => g)

占用内存大小:145536

可以看到,使用不缓存结果集的方式获取一行结果所占用的内存是极少的。这样就结局了超出内存限制的问题。

如果觉得《如何解决PHP使用mysql_query查询超大结果集超内存问题【PHP】》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。