位置: 编程技术 - 正文

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

  • 个人所得税年终奖单独计税怎么操作
  • 沥青混凝土可以放多久
  • 结转未交增值税会计科目怎么写
  • 销项税额和进项税额月底怎么结转
  • 卫生清理费计入什么科目
  • 银行理财产品的特点
  • 企业清算的种类
  • 无发票材料可以入材料账吗
  • 车间领用周转材料会计分录怎么写
  • 两个公司成立一个新的公司注意事项
  • 预售房提前还款需要去解押吗
  • 一张发票多个单位报销,怎么分辨
  • 哪些营业外收入需要缴纳增值税
  • 上月工资多计提了怎么调整
  • 金蝶软件如何设置单价小数点
  • 法律责任的具体内容
  • 固定资产减值准备增加记哪方
  • 计提以前年度税金
  • 离职补偿金公司不付怎么办
  • 收到上级补助收入怎么记账
  • 和别人合作投资后悔了怎么说
  • 公司没成本票怎么暂估
  • 增值税发票总金额是含税金额吗
  • 出口退税和增值税抵扣一样吗
  • 软件开发过程中必须伴有质量保证活动
  • windows11家庭版本地策略组
  • 微信打开链接无法滑动
  • 本月无生产,有折旧怎么办
  • 查补以前年度增值税怎么申报
  • 讲述人功能怎么关闭
  • 备份计算机需要多久
  • 宽带连接错误代码691
  • vue中如何使用weboffice
  • php注册功能的实现
  • 房产证办理流程图
  • 股东退股怎么分钱
  • 购买房屋缴纳的税款
  • php分页查询的简称是什么
  • 金蝶存货核算不能结账,能强制结账吗
  • js必学知识点
  • 销售折扣购物卡怎么做账
  • 客运公司做账怎么做
  • 购入的机器设备
  • 投标保证金退还时间是在什么文件的规定的
  • db2入门视频教程
  • 用于app服务端的加速器
  • mysql数据库常用sql语句
  • 织梦怎么用模板建站
  • 软件企业该怎么发展起来
  • 农业发展公司有没有库存商品的
  • 劳动仲裁赔偿款会计分录
  • 小规模纳税人分红要交税吗
  • 无形资产界定
  • 制造费用的核算内容包括什么
  • 公司之间借款计入什么科目
  • 汇算清缴可以调整主营业务成本吗
  • 发票隔年还能做账吗
  • 房地产公司开发的商品房应作为固定资产核算
  • 新办企业必须经过什么核准登记
  • 总账的设置和登记实训报告
  • mysql一闪而退
  • 怎么修改注册表的权限
  • ubuntu文本编辑器怎么打开
  • securecrt教程
  • xp系统怎么设置不待机
  • windows下打开注册表的命令是什么
  • linux rm 命令删除文件恢复
  • win7系统监控
  • cocosdx让AppDelegate支持全局更新机制
  • Bullet(Cocos2dx)之封装PhysicsWorld3D
  • [置顶]游戏名 TentacleLocker
  • chrome heat
  • unity soket
  • JavaScript中的复杂数据类型又称为
  • js实现滑动效果
  • 深圳国税电子税务局
  • 水利优惠政策
  • 国税怎么取消
  • 陕西陉阳县税务局官网
  • 税务部门放管服
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设