位置: 编程技术 - 正文

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

  • 个人出租汽车
  • 一般纳税人财务要求
  • 简易计税征收率是多少
  • 财务刷卡手续费怎么处理
  • 月末结存材料的实际成本例题
  • 实习生个人所得税需要申报吗
  • 银行入息是入几个月的
  • 电商存货周转率的正常范围
  • 应收账款项目分析思维导图
  • 租车费属于办公费吗
  • 工程劳务分包合同中的分包范围
  • 私对公转错了多久退回来
  • 不动产增值税怎么算
  • 生产型企业出口非自产产品能享有退税吗
  • 辅导期一般纳税人预缴增值税
  • 请问哪些福利费不用交税
  • 增值税发票的基数是什么
  • 一次性收取跨年租金房产税怎么交
  • 收到公司投入的土地使用权
  • 建筑业月末账务处理
  • 普票需要缴纳印花税吗
  • 社保企业报盘是什么
  • edge浏览器设置主页网址
  • 净资产收益率公式推导
  • 行政单位房租收入上交分录
  • 收到对方给的发票怎么做账
  • 个人所得税计算方法及抵扣方法
  • 存货损失进项税
  • 企业所得税汇算清缴会计分录
  • php数组函数题目
  • 喀拉拉邦地理位置
  • 租用办公设备
  • 当月计算的增值税怎么算
  • 企业支付给员工的一次性伤残就业补助金计入哪项费用
  • 两个岗位 如何选择
  • html盒子边框圆角
  • 定额发票累计领用金额怎么填
  • css获取id
  • php面试基础题
  • 结转已销产品计入什么科目
  • 用人民币支付的公司
  • php实现站内消息推送
  • okhttp源码
  • 简述记账后的凭证修改方法
  • 什么叫现金流量表举例说明
  • 金税盘购买的会计分录
  • 实际出资大于注册资金
  • 库存现金余额过大的风险
  • 暂估入库的商品作暂估冲红会计分录
  • 企业相关成本费用有哪些
  • 飞机票电子发票可以抵扣进项税吗
  • 发票分割单使用范围
  • 无票收入怎么写分录
  • 金蝶当月没有账如何结转到下月
  • 专家咨询费支付标准
  • 以前年度损益调整怎么做账
  • 成品油 规定
  • 开业建账到年末怎么做账
  • 违反会计规定承担责任
  • 安装sqlserver2000 IP地址出错怎样修改
  • mysql2003错误如何解决10061
  • windows安全保护
  • centos6.8安装不上
  • 如何用u盘安装win8操作系统
  • qcwlicon.exe - qcwlicon是什么进程 有何作用
  • linux命令速记
  • windows10 2021预览版
  • js继承的关键字
  • opengl基本图形绘制
  • jquery插件开发方法
  • python设计程序
  • 黑龙江国税局官网
  • 江苏电子税务局官网登录入口
  • 怎么查询电子票是否被红冲
  • 陕西省税务局机关服务中心
  • 不动产租赁和经营租赁发票的区别
  • 地税全国联网了吗
  • 水产品 免税
  • A级纳税人和一般纳税人区别
  • 重庆市大学生田径锦标赛
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设