位置: 编程技术 - 正文

如何解决PHP使用mysql_query查询超大结果集超内存问题(如何解决php使用延迟问题)

编辑:rootadmin

推荐整理分享如何解决PHP使用mysql_query查询超大结果集超内存问题(如何解决php使用延迟问题),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php常见问题,php phyon,php的使用,php使用教程,php遇到的问题,php的使用,如何解决php使用问题,php的使用,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

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

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

Fatal error: Allowed memory size of bytes exhausted (tried to allocate bytes) in E:ProgramDevelopmentRuntimeEnvironmentxampphtdocstesttest.php on line

Call Stack:

0. 1. {main}() E:ProgramDevelopmentRuntimeEnvironmentxampphtdocstesttest.php:. 2. test->selecttest() E:ProgramDevelopmentRuntimeEnvironmentxampphtdocstesttest.php:. 3. PDOStatement->execute() E:ProgramDevelopmentRuntimeEnvironmentxampphtdocstesttest.php:

如何解决PHP使用mysql_query查询超大结果集超内存问题(如何解决php使用延迟问题)

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

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

最初占用内存大小:

占用内存大小:

占用内存大小:

占用内存大小:

占用内存大小:

占用内存大小:

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

Zend Framework教程之Bootstrap类用法概述 本文实例讲述了ZendFramework中Bootstrap类用法。分享给大家供大家参考,具体如下:Zend_Application_Bootstrap_BootstrapperZend_Application_Bootstrap_Bootstrapper是所有引导

Zend Framework自定义Helper类相关注意事项总结 本文讲述了ZendFramework自定义Helper类相关注意事项。分享给大家供大家参考,具体如下:编写自定义的Helper类编写自定义的Helper类很容易,只要遵循以下

Zend Framework教程之Application用法实例详解 本文实例讲述了ZendFramework教程之Application用法。分享给大家供大家参考,具体如下:Zend_Application是ZendFramework的核心组件。Zend_Application为ZendFramework应用

标签: 如何解决php使用延迟问题

本文链接地址:https://www.jiuchutong.com/biancheng/290951.html 转载请保留说明!

上一篇:Zend Framework教程之资源(Resources)用法实例详解(zendframework3)

下一篇:Zend Framework教程之Bootstrap类用法概述(framework core)

  • 增值税纳税申报时间
  • 增值税进项税额不得抵扣的几种情形
  • 个人所得税计提和发放分录
  • 什么是减免税额90%
  • 实际负税计算公式
  • 进项税跟增值税
  • 土地使用权转让是什么意思
  • 销售材料的会计分录在实务第几章节
  • 增值税普通发票需要交税吗
  • 取得虚开普票怎样补增值税
  • 受托代销商品款和受托代销商品的区别
  • 营改增各项业务销售额按照什么确定
  • 纳税人和征税对象的区别
  • 企业出售房屋交什么税
  • 虚开发票可以做进项税额转出分录吗?
  • 公司租车费用会计分录
  • 银行代收费业务会计分录
  • 新公司注册后先开户还是先税务登记
  • 用于当年免征的增值税
  • 其他应收款要做账吗
  • 人防设施建设费
  • 分公司可以列为被告吗
  • 网税系统用户名和密码
  • 购买银行承兑汇票的会计分录
  • 小规模纳税人补开发票如何申报增值税
  • 小规模免征增值税政策2022
  • 1697510649
  • 供应商质量扣款
  • Mac怎么更改锁屏密码
  • 保险公司报销工伤手续需要哪些手续
  • 股东向公司借款协议书范本
  • 应付票据转应付账款分录
  • 提前支付的费用记账
  • vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)
  • 生产车间人员招聘要求
  • 医疗知识科普图片
  • windows. location
  • 公司财务认证负责人实名认证需要承担责任吗
  • 什么是长期应付票据
  • html前端开发教程
  • yolov5增加检测层
  • es6面试题promise
  • mysql_install_db命令 初始化MySQL数据目录
  • 企业借款生产存货发生的借款费用均应予以资本化
  • mongodb数据库操作题
  • 营业成本包含折旧和摊销吗
  • 进项税额转出和红字冲销区别
  • 业务招待费专用会计科目
  • 公司购买的家电怎么入账
  • 小规模增值税减免
  • 用美元账户余额怎么用
  • 材料抵扣进项税额
  • 金蝶旗舰版的数据怎么在标准版打开
  • 现金日记账与现金流量表的区别
  • 企业商品销售收入确认条件
  • 政府机关有纳税人吗
  • mysql允许字段为空
  • mac中mysql应该怎么运行
  • xp系统net framework 3.5
  • wps2019视频
  • xp光盘安装教程
  • netsh cmd
  • xp系统文件夹选项在哪
  • winxp系统介绍
  • linux中mail命令
  • win8应用商店废了
  • win10关闭defender方法
  • win7系统回收站不见了怎么办
  • msn无法登录
  • cocos开发android游戏
  • opengl编程宝典
  • jquery动画库
  • HTML5 WebStorage(HTML5本地存储技术)
  • easyui combobox设置值
  • socketio视频教程
  • unity3d入门视频教程
  • Cannot run program "/home/mohemi/Program/adt-bundle-linux-x86_64-20130729/sdk//tools/emulator": erro
  • jquery获取php变量
  • 纳税人总机构和分机构不在同一县怎么办
  • 宁波市开发区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设