这篇文章主要介绍了PHP使用mysql_query查询超大结果集超内存怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获、下面让小编带着大家一起了解一下。
再使用mysql_query查询超大结果集的时候会出现超出内存限制的致命错误,这是因为mysql_query采用的是查询全部结果然后把结果集全部缓存到内存中的方式。
mysql的查询还提供了另外一种查询方式,函数名为mysql_unbuffered_query,这个函数采用的是查出结果后立即操作结果集,并不会把结果集缓存到内存中,这样就避免了超出内存的情况发生。但是使用这个方法的代价就是不能再查询的时候使用获取总行之类的方法,因为这种方法是便查询边返回结果。同时在使用该方法的时候不能在同一数据库链接上执行其他的操作,想要执行其他操作的时候必须先终止当前操作,释放所有未缓存的sql查询所产生的结果行,或者重新实例化一个数据库连接,使用新链接进行其他操作。
以下是使用缓存和不使用缓存的对比(所查询的表中有1000多万行数据):
function 选择() { try { pdo 美元;=,new PDO (“mysql:主机=localhost; dbname=test",, & # 39;根# 39;,,& # 39;123456 & # 39;);//,不使用缓存结果集方式//,pdo→美元setAttribute (pdo:: MYSQL_ATTR_USE_BUFFERED_QUERY,,假); 美元$ sth =, pdo→准备(& # 39;select *,得到测试# 39;); $ sth→执行(); echo & # 39;最初占用内存大小:& # 39;,只memory_get_usage(),只“\ n"; 小姐:美元=,0; while (result 美元;=,$ sth→获取(PDO:: FETCH_ASSOC)), { 小姐:美元+=,1; if (美元小姐:祝辞,10),{ 打破; } 睡眠(1); print_r(结果); echo & # 39;占用内存大小:& # 39;,只memory_get_usage(),只“\ n"; } },catch (Exception $ e), { echo $ e→getMessage (); } }
上面使用到的是缓存所有结果集的方式,运行该函数时将会报超内存的错误,如下所示:
致命错误:允许耗尽内存大小为134217728字节(试图分配204800000字节)E: \ ProgramDevelopment \ RuntimeEnvironment \ xampp \根\ test \ test.php>数组 ( (id),=在1 [一],=祝辞,v [b],=祝辞,w [c],=在我 )
占用内存大小:145544
数组 ( (id),=祝辞;2 [一],=祝辞;b [b],=在l [c],=在问 )
占用内存大小:145544
数组 ( (id),=祝辞;3 [一],=祝辞,m [b],=在p [c],=在h )
占用内存大小:145536
数组 ( (id),=祝辞;4 [一],=在j [b],=在我 [c],=祝辞;b )
占用内存大小:145536
数组 ( (id),=祝辞;5 [一],=在问 [b],=在g [c],=在g )
占用内存大小:145536
可以看的到,使用不缓存结果集的方式获取一行结果所占用的内存是极少的。这样就结局了超出内存限制的问题。
感谢你能够认真阅读完这篇文章,希望小编分享的“PHP使用mysql_query查询超大结果集超内存怎么办”这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!