位置: 编程技术 - 正文

如何解决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)

  • 如何查商品税收分类编码
  • 二手房个人所得税是买方交还是卖方交
  • 个税退还会计分录
  • 待摊费用和无形资产摊销
  • 广告公司可以不交社保吗
  • 存货的期末余额在借方还是贷方
  • 采购砂石料无发票对税务有影响
  • 疫情期间发生的费用进什么科目
  • 合并报表是按年还是按月
  • 增值税普票可以开给个人吗
  • 旅游公司如何缴费
  • 软件委托开发合同印花税
  • 公司买车可以抵扣哪些税
  • 个人住房契税2021年收费标准
  • 商业汇票如何申领
  • 小规模纳税人开票税率
  • 换汇成本太低怎么处理?
  • 应付税费包括
  • 收取加盟费会计如何入账
  • 受托加工物资如何做账
  • 发票 抵扣联
  • 增值税检查调整科目已经删除
  • 增值税普票没有地址电话开户行信息可以吗
  • 金税三期啥意思
  • 变相处理问题什么意思
  • 电子承兑汇票怎么打印出来
  • 收到财付通打款认证冲减财务费用怎么做分录
  • 现金福利支出需要申报个税吗
  • 进料进口
  • xp从做系统
  • 请等待当前程序完成或更改怎么弄
  • 腾讯电脑管家下载
  • PHP:oci_pconnect()的用法_Oracle函数
  • 利息如何做会计分录
  • 预提费用是啥
  • 建筑企业挂靠账务怎么处理?
  • 工程审计需要什么条件
  • php完整教程
  • 促销费可以进项抵扣吗
  • 递延所得税资产和递延所得税负债
  • 给大家分享几个网站
  • 计算机领域划分
  • 小程序和h5页面的区别
  • ChatGPT及相关产品体验与研究
  • mysql 临键锁
  • 开发票零税率和免税是一样的意思吗
  • 主营业务成本记错了怎么调整
  • 差旅费计入什么
  • linux mongodb基本操作
  • 小规模纳税人现代服务税率
  • 受托方代扣代缴增值税、消费税的纳税人
  • 什么叫金税四期呢?
  • 纳税申报怎么做
  • 商誉是成本法还是收入法
  • 企业商品报废如何处置
  • 利息收入红字如何入账
  • 外贸企业出口货物的计税依据
  • 成品油经销企业资质
  • 现金流量表现金及现金等价物净增加额
  • 工程进度开票如何入账
  • 私人边际成本怎么算
  • 会计工作移交的时候需要有谁在场
  • 国企背书是什么意思
  • 建账时都要建哪些科目
  • win10电脑系统配置
  • win7偶尔黑屏
  • 电脑周边是什么
  • ubuntu12.04.5安装教程
  • windows8怎么调整亮度
  • 老电脑安装win7还是win8
  • xp电脑关机后自动重启是什么原因
  • 疯狂冰淇淋罗德
  • 高效的python
  • 压缩的linux命令
  • 噩梦原版
  • sell脚本
  • unity ugui组件
  • Python字符串数组
  • 钢材出口关税税率是多少
  • 东莞国税咨询电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设