位置: 编程技术 - 正文

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

  • 工程施工的间接费用怎么结转
  • 油补是福利费还是工资
  • 专票3个点和6个点哪个多
  • 车辆租赁发票税点
  • 企业缴纳残疾人保证金按什么标准缴纳
  • 餐饮业加计递减怎么算
  • 没收逾期未退包装物押金收益,应计入( )科目
  • 业务招待费如何调增调减
  • 交印花税合同金额怎么算
  • 应付职工薪酬明细账模板
  • 计入固定资产的土地
  • 工人保险一个月多少钱
  • 一个月怎么控制花一千块
  • 开物流公司能挣多少钱
  • 个体工商户可以给自己交五险一金吗
  • 预付油卡怎么入账
  • 调整以前年度应付
  • 收到上级补助收入怎么记账
  • 电子税务局如何查询已开发票
  • 败诉赔偿如何支付
  • 企业所缴税款能抵税吗
  • 装修工程需要预缴吗
  • 继承有个人所得税吗
  • windows11开始菜单怎么居中
  • win10无法设置pin码怎么办
  • 腾讯电脑管家帮忙卸载
  • 非正常损失的进项税额如何计算
  • 360se进程太多
  • 应付票据转应付账款分录
  • 贴吧热门评论
  • PHP:Memcached::set()的用法_Memcached类
  • 生产加工型企业安全隐患排查内容
  • 非居民企业股权转让特殊性税务处理
  • 应交税费应交增值税明细账怎么填
  • 现代服务业进项税加计扣除申报怎么填
  • 金蝶专业版怎么用
  • 微擎框架破解版v2.7.7
  • python中切片用法
  • 物流公司主营业务怎么写
  • 调整以前年度亏损
  • 二手房过户需要户口本吗
  • 什么是国有划拔土地私房
  • mysql 自动重启
  • 未开票收入如何记账
  • 存货周转率作为控制变量
  • 工会经费和福利费绩效目标怎么写
  • 增加固定资产原值后折旧
  • 周转材料计入现金流量表
  • 主营业务税金及附加借贷方向
  • 一次性收取的房租如何做账
  • 客户赔款会计科目
  • 车辆保险费没有发票会计分录
  • 资产减值损失和资产处置损益区别
  • 绿化植物税率
  • 管理费用是负数影响利润表吗
  • 企业的固定资产由于技术进步等原因
  • 企业所得税和增值税重复收税了吗
  • 企业投资人类型怎么选
  • mysql 5.5 5.6
  • 同一个sql语句 连接两个数据库服务器
  • xp系统环境变量
  • ie11 ua
  • ubuntu20.04软件中心
  • win10预览版和正式版区别
  • linux root用户登陆
  • win8.1操作界面
  • JavaScript运算符中谁拥有最高优先级
  • jquery validation
  • [置顶]游戏名:chivalry2
  • jquery对象可以直接使用dom吗
  • python django事务transaction源码分析详解
  • 通过jquery实现页面的动画效果(实例代码)
  • jquery鼠标移入移出切换图片
  • ORMLite完全解析(四) 官方文档第四章、在Android中使用
  • 基于jQuery的ajax方法封装
  • 江苏4050社保补贴政策2024
  • 代发工资法律依据
  • 中国一年能收多少税
  • 如何下载电子国税app
  • 纳税服务理念创新不足
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设