位置: 编程技术 - 正文

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

  • 应交税金和应交税费有啥区别
  • 先申报财务报表还是企业所得税汇算清缴
  • 不抵扣勾选怎么撤销
  • 什么是资本性支出和支出
  • 企业统计报表怎么写
  • 代理服务费收取标准
  • 购销印花税会计分录
  • 出售生产线计入哪里
  • 公司报销专用发票
  • 收到政府中小企业发票
  • 增值税普通发票和电子普通发票的区别
  • 公司购买电脑费用怎么报销
  • 91开头的税号是什么
  • 食堂费用计入应付职工薪酬吗
  • 新办企业税务办理
  • 公允价值上升是收益还是损失
  • 企业核销应收账款需要什么资料
  • win10玩游戏太卡了
  • 最新双色球开奖号码
  • 出口退税申请流程
  • 企业筹资付给第三方账户
  • 库存呆滞品处理方法
  • 承租人对经营租赁和融资租赁会计处理方式
  • 软件入无形资产金额
  • 公司党员活动日方案
  • 最贵的一个苹果多少钱
  • 404 not found意思详细介绍
  • 个人签订的出租协议
  • yolov8训练自己的数据
  • 从上魏斯巴赫山地列车的车站向外看,德国图林根 (© golero/iStock/Getty Images Plus)
  • 索尔兹伯里评价
  • 增值税会自动申报吗
  • 浏览器集成什么意思
  • opencv识别车牌
  • 企业小微企业贷逾期起诉法人房子会被拍卖吗?
  • 固定资产停止使用还要折旧吗
  • 企业所得税年报截止日期2023
  • php验证码代码怎么写
  • 残保金滞纳金可以税前扣除吗
  • 关于进项票少的解决方案
  • 项目竣工决算审查
  • 联营企业有重大影响吗
  • 母公司与子公司的区别
  • 常见数据库系统软件
  • mysql数据表存储引擎
  • sqlserver数据库定时任务
  • mysql组合
  • 个体户生产经营所得
  • 增值税专用发票丢了怎么补救
  • 进项票未认证就申报抵扣
  • 其他单位无偿过账合法吗
  • 事业单位劳务派遣是啥意思
  • 业务招待费比例控制规定
  • 收到银行借款并存入银行会计分录
  • 现金日记账是会计人员根据审核后的
  • 企业计提坏账准备形成可抵扣暂时性差异
  • 一达通退税需要具备的条件?
  • 费用误计入固定资产
  • 金税盘技术维护费可以不交吗
  • 公司向个人借款利息可以税前扣除吗
  • 施工单位月末都需要结转什么
  • 运输过程发生的合理损耗计入成本吗
  • wind2003
  • winxp怎么设置启动项
  • winxp如何将两个分区合并成一个分区
  • linux cp 不是目录
  • iptables用法
  • 添加或删除程序在哪win10
  • win10 edge浏览器崩溃
  • opengl语言
  • js中正则表达式语法
  • 音频焦点图广告
  • jquery 设置checked
  • python import怎么用
  • jquery中删除节点方法
  • js实现功能
  • [置顶]电影名字《收件人不详》
  • 工行网银如何申请发票
  • 公租房要钱吗
  • 佛山电动摩托车能上牌吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设