位置: 编程技术 - 正文

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

  • 营业外收入要交企业所得税吗
  • 什么情况下不能做近视激光手术
  • 增值税审核表
  • 预算会计无偿调拨净资产
  • 银行对账单由谁去取
  • 其他收益科目在哪个科目前面填
  • 社保计入主营业务成本
  • 付款给对方的会计分录
  • 所得税费用增加利润减少
  • 即征即退项目的进项税额不参与加计抵减
  • 员工本地住宿费会计分录
  • 煤炭企业会计制度
  • 贸易型出口退税流程
  • 进行利润分配时必须遵循的原则
  • 单位表彰性奖金是什么
  • 保函保证金怎么审计
  • 留底的预缴税款怎么处理?
  • 公司的一些党员特别喜欢健身
  • 增值税普通发票和专用发票有什么区别
  • 纳税人财务核算及申报纳税情况报告
  • 旅行社差额纳税发票怎么开具
  • 小微企业按季度报送财务报表
  • 增值税抵扣联退税多少
  • 供应商返点抵应怎么做账
  • 总资产报酬率
  • 公司党支部的费用入账
  • 营业执照副本编号是指什么
  • 小规模企业如何收款
  • 冲减材料采购成本
  • 汇丰银行账户管理费
  • 苹果6手机蓝牙
  • thinkphp withjoin
  • ev4是什么文件
  • 公寓增值税税率是多少
  • linux 运行php
  • 个体工商户和个人独资企业的区别
  • 待摊费用在资产负债表中怎么表示
  • 税控盘费和服务费都可以减免吗
  • 小微企业材料
  • 土地开发成本包刮
  • mysql同步复制搭建方法指南详细步骤
  • 企业返聘退休人员需要交社保吗
  • 收据作为原始凭证的依据
  • 企业会计凭证怎么写
  • 甲企业持有乙企业40%的股权,能够对乙企业
  • 行政单位现金管理
  • 外经证适用范围
  • 以前期间留抵税额是什么意思
  • 公司租赁办公场所,没发票怎么办
  • 房地产影响投资和消费,事关民生和发展
  • 业务招待费可以开专票抵扣吗
  • 年度所得税未在第一季度所得税申报前汇算清缴
  • 探望公司员工现金费用报销怎么写
  • 五险怎么做账
  • ubuntu安装教程14.04
  • sql语句 字符串
  • windows性能监视器怎么用
  • 无光驱是不是放不了光盘
  • vic32.dll是什么
  • 直通车和百度竞价的区别
  • ubuntu lnmp环境搭建
  • vsftp查看状态
  • assoc .exe=exefile是什么
  • giantantispywaremain.exe是什么进程 有什么作用 giantantispywaremain进程查询
  • linux yum安装apache
  • win10新建文件夹的快捷键是哪个
  • win10资源管理器快捷键
  • win10系统异常自动重启
  • linux常用的帮助命令
  • 如何实现js对象和json数据互转
  • python生成矩阵的方法
  • 归档 oracle
  • android 侧滑页面
  • javascript常用函数大全
  • javascript基础教程pdf
  • python黑帽子怎么样
  • 电子税务局获取验证码异常
  • 临时占地耕地占用税纳税义务发生时间
  • 河南省地方税务局电话
  • 从事货物批发或零售的纳税人
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设