位置: 编程技术 - 正文

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

  • 福利费进项税额转出会计分录账务处理
  • 业务招待费的税金可以抵扣吗
  • 高新技术企业产品是什么意思
  • 自有住房出租
  • 企业重组的特殊性税务处理比例
  • 税负率的计算方法有哪些
  • 车船税发票可以作废吗
  • 一般户用途可以是往来款吗
  • 出纳可以做库存库吗
  • 出口业务退税流程资料
  • 转移性支出主要影响社会的什么领域
  • 应收账款转入呆账如何做帐
  • 净现值为零时的收益率
  • 固定资产的折旧方法一经选定,不得随意变更
  • 呆账的处理
  • 应付账款坏账准备的会计分录
  • 建设厂房需要几个证
  • 重新建账要以前的期初余额吗
  • 物业管理公司如何纳税
  • 建设单位增值税抵扣
  • 什么是工会经费返还
  • 商票背书需要对方开发票吗
  • 工资年终奖金扣多少税
  • 支付青苗补偿费怎么做账
  • 大额转账人行审核通过
  • 收到的劳务费发票可以抵扣吗
  • 社保公积金外包对员工的利弊
  • win10取消登陆密码
  • vnisedit 打包
  • win7怎么运行在哪里设置
  • 长期待摊费用摊销明细表
  • 冲销货款应怎么记账
  • VMware虚拟机中怎么复制粘贴
  • php数组查找
  • 员工的出差补贴计入什么科目
  • surface pro记笔记
  • 发代扣代缴手续费个税免
  • threejs环境搭建
  • 应对怯场的方法
  • 房地产开发企业增值税怎么算
  • 企业所得税计提会计分录怎么做
  • 阿尔莫什
  • 何为前端后端
  • 成本费用损失的区别和联系
  • php socket_create
  • 如何使用php给图片命名
  • 为什么要结转成本?
  • 移动平均法适用范围
  • php框架 hyperf
  • 抵扣完进项怎么算应交增值税
  • 企业所得税汇算清缴补缴税款分录
  • 年均复合增长率该怎么算?
  • 企业所得税本年累计
  • 工会支付职工福利费做账
  • 运动会活动奖品
  • 转入企业银行存款利息分录
  • 旅行社差额征收怎么报税
  • 代开租金发票的税金怎样入账?
  • 出包方式建造固定资产的成本包括
  • 技术开发免税收入怎么算
  • 不是企业职工能否挂靠企业交社保
  • 出口免抵退和免退有什么区别
  • 金蝶系统如何设置套打
  • 如何开发票?
  • 发生以下情况
  • 五金行业怎么开店
  • 连接mysql数据出错1045
  • sqlserver Union和SQL Union All使用方法
  • sql server数据库查询语句
  • win10exe文件关联修复
  • win7系统分辨率调错了黑屏
  • macbookair扫描文件怎么弄
  • linux中密码信息存在哪个文件
  • shell脚本语句
  • css制作热点新闻板块
  • jQuery用FormData实现文件上传的方法
  • 原生js页面滚动怎么设置
  • 环保税申报流程视频
  • 农机作业服务费用 如何开发票
  • 有关单位和个人应该怎么样
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设