位置: 编程技术 - 正文

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

  • 只报税不做账有什么后果?
  • 收据盖公章要注意哪些
  • 企业缴纳残疾人保证金按什么标准缴纳
  • 新政府会计准则2019
  • 公司账户被法院冻结了多久可以恢复
  • 支付外币投资会计处理
  • 银行承兑逾期证明怎么写
  • 房地产开发项目手册备案
  • 转让房地产增值税
  • 被投资单位提取盈余公积权益法
  • 税收优惠退回的税金怎么入账
  • 不良产品出库维护制度
  • 汽车进口税率表
  • 捐助建学校
  • 销项发票采集不出来怎么回事
  • 税务局查账一般需要几天
  • 农产品流通环节税收优惠政策
  • 租车服务的税率
  • 集团统借统还利息
  • 开票的时候如何把价格分散开
  • 行程单燃油附加费可以抵扣吗
  • 直系亲属之间转账要交税吗
  • 增值税专票已经认证
  • 职工教育经费取得证件之后补助多少钱
  • 参加抽奖活动中奖却不发奖品
  • 营业收入现金怎么计算
  • 电梯维保公司缴税标准
  • 系统升级为win11
  • 以前年度损益调整借贷方向
  • 废品损失涉及的税种
  • mac开机按command+r没反应
  • 劳务费和服务费税率一样吗
  • 公司购买预付卡送礼怎么入账
  • mac更新内容
  • 部shu
  • rsa前端解密
  • php实现数据批量导入
  • thinkphp分表
  • 增值税税负指标怎么算
  • async/await原理
  • php删除数组中指定元素
  • Visual studio 2019 社区版下载和安装
  • 扩散模型和gan的区别
  • 建厂购买材料的会计科目
  • 个人以不动产投资成立一人有限公司
  • 股东分红后股票会涨吗
  • 固定资产清理的金额怎么算
  • 税负率包含哪些税种
  • 企业注销后还会查账吗
  • 企业研发费用的优惠政策
  • 公司模具部制作工作内容
  • 用友软件数据导出
  • 高新技术企业的申报条件
  • 税金及附加核算哪些税费
  • 按预测范围不同划分为以下几类
  • 摊销本月的广告费合理吗
  • sqlserver数据库怎么导出
  • pe explorer
  • 电脑被攻击了怎么修复
  • debian openssh
  • Cpqset.exe是什么系统进程 Cpqset有啥作用
  • mac之间传送帐号怎么传送
  • linux bin和sbin
  • shell 时间格式
  • linux 压缩rar
  • node.js的express
  • 使用netcat(瑞士军刀)进行文件传输
  • dos字符串替换
  • 超级链接是什么意思
  • vue自定义过滤器的语法
  • 文件包解密
  • unity简单小游戏案例
  • jquery双击
  • nodejs mocha
  • python内置数据结构有哪些
  • 发票查验结果怎么保存
  • 公积金提取需要几个工作日
  • 重庆两江新区总工会社会化工作者待遇
  • 税务稽查审理的基本原则
  • 车间租金计入什么会计科目
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设