位置: 编程技术 - 正文

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

  • 所得税清算扣除比例
  • 三方代付协议有效吗
  • 汇算清缴是不是按照审计报告
  • 海运的发票可以抵税吗
  • 10万以内免交的增值税怎么做帐
  • 利息费用和利息支出的区别计算公式
  • 其他债权投资减值账务处理
  • 企业所有职工都要交税吗
  • 对赌协议补偿款计入哪个科目
  • 库存商品内部划转怎么做账?
  • 基本户上的钱打到个人账户上,写什么用途
  • 发票认证费用
  • 企业所得税根据什么报表申报
  • 公司发放节日礼品
  • 事业单位乱报销出纳怎么办?
  • 税后工资反推税前工资计算方法
  • 输入开票码开具电子发票
  • 所得税季报季末从业人数怎么填
  • 资本公积转增资本个人股东是否纳税
  • 公司对外投资的规定
  • 税控系统维护费280会计分录
  • 联营商场如何交增值税?
  • 所得税年报报完了怎么更正季报
  • 现在还有短期投资这个科目吗
  • 工会经费该怎么交
  • win10任务栏向上的箭头不见了
  • 计提工资和发放工资区别
  • 电脑qq音乐设置在哪里
  • 认缴出资额日期没有是什么意思
  • win11dev预览修复工具
  • mcshield.exe是什么进程
  • 恶搞代码vbs教程
  • Eclipse PHPEclipse 配置的具体步骤
  • rk3566 rk3288
  • vue-introjs
  • vuejs axios
  • 静态html怎么部署到服务器
  • 税费滞纳金计入增值税吗
  • 预付款项属于什么
  • python 微信
  • 客户不要的专票我们可以不作废吗
  • 应收利息会计分局
  • uniapp组件使用
  • 帝国cms真的很好用
  • 其他综合收益影响所得税费用吗
  • 金融企业往来支出科目属于什么科目
  • 差旅费抵扣进项税额
  • 捐赠会计和税法上各怎么记录
  • 一般纳税人简易计税方法适用情形
  • 销售费用期末余额
  • 制造费用科目一定无余额
  • 预缴土地增值税税率表2023年最新
  • 小规模以前年度城建税未计提
  • 固定资产公司
  • 原材料 半成品
  • 房产税怎么实行
  • 帮别人维修东西怎么开票
  • 委托加工科目有余额嘛
  • 银行手续费未取得发票可以进行税前扣除吗
  • 单位购牙膏牙刷卫生纸怎么做账?
  • 发票金额大于付款金额可以报销吗
  • 食堂没发票如何记账
  • 普通发票如何抵扣税
  • windowssystem32configsystem下载
  • linux服务器怎么用
  • centos 中文
  • Fedora 9.0 Apache+PHP+MYSQL 环境安装
  • wmpdmc.exe是什么意思
  • 直通车和百度竞价的区别
  • mac双系统删除mac系统
  • lsaass.exe
  • win8电脑锁屏壁纸怎么设置方法
  • rtk api error=3
  • win8怎么系统重装系统
  • Win10 Mobile Build 14327上手视频评测
  • nodejs连接达梦数据库
  • linux tcp keepalive
  • nodelink
  • 办理跨区域事项报验
  • 建筑行业增值税税率2021
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设