位置: 编程技术 - 正文

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

  • 一般纳税人开劳务发票几个点
  • 金税三期是什么时候投入使用的
  • 如何成为一般纳税人的条件
  • 冲减以前年度的成本会计分录
  • 其他应付款计入资本公积
  • 收回的伙食费计什么科目
  • 汇算清缴退回的所得税
  • 单位购买预付卡
  • 进销存账需要合并吗
  • 银行回单可以做收入吗
  • 航运(集团)招聘
  • 未到期责任准备金计算方法
  • 办公设备折旧年限及残值率
  • 个人所得税的税收优惠项目有哪些
  • 增值税税控盘抵减
  • 所得税季度申报表营业成本怎么填
  • 建筑施工的会计科目
  • 对方公司税务注销了发票没有开给我怎么办
  • 个人所得税做账怎么做
  • 税务代开的专票未取票,逾期会作废吗?
  • 机票的保险费能开发票吗
  • 个人销售自己使用过的物品免征增值税
  • gsicon.exe是什么进程 作用是什么 gsicon进程查询
  • win10无法运行软件怎么回事
  • 竣工结算的依据有哪些?
  • 为什么无线网密码对了就是连不上网
  • 已开票未收款怎么做账
  • 怎么检查当年的核酸结果
  • 应交增值税视频讲解
  • 职工工资扣税比例
  • node升级版本
  • 财政总预算会计分为几级
  • 采用定额法计算产品成本,其程序如何?
  • 借应付职工薪酬贷其他应收款
  • 部门差旅费预算表
  • python 命令行参数解析
  • 原材料暂估入库成本结转处理
  • 工伤补贴如何做帐
  • 劳务派遣公司账务处理
  • 会计信息不采集有什么后果
  • 支付工程款的会计科目怎么写
  • 开专票明细太多怎么开
  • 政府补助怎么判断总额法还是净额法
  • 出口退税是什么
  • 公司减免的社保退给个人吗
  • 营改增企业可以转小规模吗
  • 合同取得成本和销售费用
  • 在建工程项目包括
  • 外资企业对应的企业是什么
  • 预提与计提的区别在哪里
  • 取暖费用摊销吗
  • win10预览版退回正式版
  • linux的apache
  • 索尼笔记本电脑怎么进入bios设置
  • cmos电池没电会有什么故障现象
  • ubuntu下载net-tools
  • linux网卡lo
  • linux中dhcp
  • centos minio
  • 系统导航栏已禁用怎么办
  • win7系统开机
  • win10自带绘画
  • linux 的ll
  • redhat linux yum
  • opengl画点
  • 快速掌握日语词汇
  • opengl用法
  • 安卓deprecated
  • js数组随机抽奖
  • shell脚本转码
  • nodejs接收form表单
  • jquery原理解析
  • 税务局电话客服人工服务
  • 小规模纳税人进口环节的增值税税率
  • 工商跟税务的区别
  • 重庆市税收排名地区
  • 一般纳税人沙石税率是多少
  • 公务员考试税局
  • 河南濮阳市供电公司何文中个人简历
  • 扶贫绩效目标申请怎么写
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设