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

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

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

function selecttest()

{

try {

$pdo = new PDO("mysql:host=localhost;dbname=test", 'root', '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

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

mysql query结果集_如何解决PHP使用mysql_query查询超大结果集超内存问题相关推荐

  1. mysql查出的结果太大 php_如何解决PHP使用mysql_query查询超大结果集超内存问题

    再使用mysql_query查询超大结果集的时候会出现超出内存限制的致命错误,这是因为mysql_query采用的是查询全部结果然后把结果集全部缓存到内存中的方式. mysql的查询还提供了另外一种查 ...

  2. mysql 主从同步 阻塞_如何解决主从数据库同步延迟问题?

    题主说的方案感觉非常不靠谱. 不过mysql-proxy本人也几乎没怎么接触,它能否实现上诉功能有些不大确定,即使它有,也不建议为了这个就用它,官网自己都不推荐用到生产环境. 针对主从延迟,本人的经验 ...

  3. mysql删除端口配置文件_完美解决phpstudy安装后mysql无法启动(无需删除原数据库,无需更改任何配置,无需更改端口)直接共存...

    今天学习php,当然是要先安装好运行环境了,phpstyudy是一个运行php的集成环境, 一键安装对新手很友好,与时作为一个新手,便跟着教程安装了phpstudy集成环境. 很快安装好了,嗯.对新手 ...

  4. mysql 运行sql 编码_关于解决运行 sql 文件时, 找不到 MySQL 默认编码 utf8mb4 的问题...

    关于解决运行 sql 文件时, 找不到 MySQL 默认编码 utf8mb4 的问题 本人小白一名, 最近碰到了一个问题, 在 navicat 导入 MySQL 文件时, 报出 MySQL 找不到 u ...

  5. mysql如何处理图片吗_如何解决mysql插入图片后缀名问题?

    inventory是库存 里边包括pic这个字段,现在要是先从inventory把图片选择出来,并插入record的pic中,但是插入之后图片的后缀名(jpg)没有了?如何解决?? 下面这个是inve ...

  6. 解决mysql的乱码问题_完美解决mysql中文乱码的问题

    MySQL(和PHP搭配之最佳组合)中文乱码的原因 MySQL(和PHP搭配之最佳组合)会出现中文乱码的原因不外乎下列几点: MySQL(和PHP搭配之最佳组合) server本身设定问题,例如还停留 ...

  7. mysql query cache 关闭_为什么要关闭MySQL query cache-Fun言

    MySQL的query cache大部分情况下其实只是鸡肋而已,建议全面禁用.当然了,或许在你的场景下还是挺好的,还能发挥作用,那就继续使用吧,把本文当做参考就好. 不过,可能有的人人为只需要把 qu ...

  8. 安装mysql程序运行出错_如何解决mysql安装后.net程序运行出错的问题

    如何解决mysql安装后.net程序运行出错的问题 发布时间:2020-09-28 17:43:58 来源:亿速云 阅读:93 作者:小新 小编给大家分享一下如何解决mysql安装后.net程序运行出 ...

  9. xampp mysql 端口被占用_如何解决XAMPP安装后提示80端口被占用

    如何解决XAMPP安装后提示80端口被占用 导语:如何解决XAMPP安装后提示80端口被占用呢?通过下面的阅读你会有所收获,大家可以参考阅读,更多详情请关注应届毕业生考试网. 第一次在本地测试word ...

最新文章

  1. oss生成唯一文件名_根据结构化自然语言规范自动生成精确预言
  2. 使用Python,OpenCV转换颜色空间,追踪对象的轨迹
  3. Google设想将《黑镜》情节变为现实,但要你的隐私作交换
  4. 从视频到语言: 视频标题生成与描述研究综述
  5. 解决Could not open requirements file: [Errno 2] No such file or directory: ‘requirements.txt‘问题
  6. MySQL- SHOW TABLE STATUS命令
  7. Lunar New Year and Cross Counting
  8. MongoDB 5.0新特性概览
  9. C++:14---虚继承,虚函数,多态
  10. hikari如何切换数据源_spring boot+mybatis 多数据源切换(实例讲解)
  11. 使用ARKit编码测量应用程序:对象和阴影
  12. 生物电(ECG、EMG、EEG)科普研究
  13. 做移动网站还是移动应用程序?
  14. 梧桐树王牌产品金玉满堂增额终身寿险下架在即,资产焦虑就买它
  15. MAME模拟器debug帮助文档汉化一(介绍)
  16. 新手必备AutoCAD练习图纸,分分钟提高你的绘图效率!
  17. 响应式(自适应屏幕)
  18. 研发管理学习笔记4-学习研发管理的51CTO视频课
  19. java 字体大小 像素_字体的大小(pt)和像素(px)如何转换?
  20. 【计算机网络】DNS域名系统

热门文章

  1. PolarMask:单阶段实例分割框架,FCOS进阶!
  2. [python Cookbook]阅读笔记
  3. 通过阿里云容器镜像服务海外服务器构建spark-operator镜像
  4. linux diff命令使用示例
  5. Ubuntu18.04完全卸载vscode
  6. 应用服务关闭时eureka客户端会向server发送销毁请求
  7. @PropertySource与@ConfigurationProperties多种方式读取配置文件详解,附带@PropertySources使用说明
  8. latex在algorithm环境或表格中插入圆圈脚注
  9. 单片机课程设计数字心率计_课程设计-基于单片机的数字人体心率计设计.doc
  10. 用python玩转数据第四周答案_用Python玩转数据_章节答案