位置: 编程技术 - 正文

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

  • 外省人员收入怎么查
  • 可以出口的商品
  • 汇兑记载事项及使用注意事项
  • 反写不了是为什么
  • 企业内部研发支出会计处理探讨
  • 存出资本保证金是金融资产吗
  • 企业清算过程中应收应付的处置
  • 职工教育经费税法
  • 资产负债表存货为负数原因
  • 吸收合并的税务处理增值税风险
  • 报关单和发票不符怎么办
  • 销售旧房不能取得评估价格
  • 捐赠利得会计分录
  • 不动产在建工程使用的外购物资可以抵扣吗
  • 工程物资与原材料的区别与联系
  • 开公司财务流程
  • 确认社保局工伤赔款会计分录
  • 免抵退和免退税哪种划算
  • 成本费用包括哪些包括外购材料吗
  • 新成立的公司季报
  • 物业公司广告位出租怎么入账
  • 外包劳务费用如何计算
  • 原材料明细账余额为零怎么写
  • 劳务报酬交的税汇算清缴能退
  • 卖护肤品赚钱吗
  • 小规模纳税人缴纳增值税怎么做账
  • configureandwatch
  • Win7系统Syswow64文件夹是什么及能否删除的相关内
  • 房地产预缴所得税的计税基础
  • 误删开始菜单
  • php判断密码长度
  • 投资担保公司的钱都去哪了
  • ai安装教程2020
  • vue图片放在哪里
  • 基于用户的协同过滤算法
  • 目标检测yolo算法
  • 房产税按照租金
  • 土地使用税的征税范围有哪些
  • 开收据可以列收入吗
  • phpcms v9安装教程
  • sql server数字类型
  • 行政事业单位福利费开支范围文件
  • 财务负责人需要承担什么风险
  • sqlserver时间戳数据更新时也修改默认时间
  • 纳税申报表期末未缴税额什么意思
  • 企业报税表格填写
  • 增值税小规模纳税人2023年政策
  • 税务ukey版怎么读入发票
  • 长期待摊费用好处
  • 合并报表存货抵消
  • 外币折算会计思维导图
  • 计提成本后如何冲回
  • 会计做账的原始凭证有哪些
  • 会计中应收账款属于什么科目
  • 银行利息收入怎么计算
  • 购买发票打印机如何账务处理?
  • 职工福利费和工会经费
  • Linux系统下Mysql使用简单教程(一)
  • win7双系统怎么设置开机选择系统
  • ubuntu configure
  • ubuntu kylin 14.04下载 ubuntu优麒麟14.04 lts下载地址
  • ubuntu16.04远程连接
  • centos的特点
  • 微软状态
  • linux删除定时任务
  • linux 去除换行
  • win7系统如何修改ip地址
  • win10非管理员账户开启管理员账户
  • win7更新显卡驱动后黑屏的解决方法
  • css实现弹窗
  • shell脚本tr
  • javascript总结
  • android自定义view ondraw有时候不执行
  • shell输出1到100
  • cmd命令format
  • unity 优化
  • 莱鸟人集团
  • 国家税务总局令第43号公告
  • 国家税务总局现任局长
  • 税务师事务所企业组织架构
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设