位置: 编程技术 - 正文

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

  • 增值税加计抵减政策
  • 医院这么开发票
  • 下列各项中免征增值税的有
  • 审计库存现金盘点方法
  • 电子发票红字发票怎么开
  • 永续盘存制的含义
  • 计提存货跌价准备是递延所得税资产吗
  • 子女教育专项附加扣除是什么意思
  • 4s店的赠品
  • 广告费收入是不是非税收入
  • 资产负债表年初余额是不是一直不变
  • 营改增后转让土地使用权怎么计算增值税
  • 个人代公司付货款要证明吗
  • 残保金属于职工薪酬吗
  • 建筑安装工程费用人工费计算方式
  • 机动车发票认证了的发票怎么红冲
  • 开发票回款是什么意思
  • 债券借贷业务属于表外业务吗
  • 电脑检测不到税控盘原因
  • 受委托研发企业可以享受研发支出吗
  • 一般户转钱到基本户
  • linux 数字
  • 调整上年度多计提的附加税
  • 上月材料入库会计分录
  • 实物资产股权投资包括
  • 资本溢价和股本差多少
  • 以商业汇票抵付应付账款会计分录
  • 重楼的功效与作用价格
  • 加工制造业包括
  • 增值税税收类型有哪些
  • 待安置期间生活补助费多少钱
  • 企业内部转账通知单
  • 阿里云主机php版本
  • php和mysql关系
  • yolo系列算法比较
  • 计算机视觉的应用
  • torch.nn.Conv3d
  • php文件上传技术
  • mysql desc(DESCRIBE)命令实例讲解
  • php生成文件函数
  • php路径问题
  • 税务局手续费返还政策
  • 逾期未收回包装物押金会计分录
  • 支出和收入怎么算呀
  • 会计备案报送期间
  • 防暑降温费用发放标准
  • 哪些合同不用计提印花税
  • 原材料暂估入库分录
  • 进项税和销项税怎么理解
  • 会计中应收账款属于什么科目
  • 企业亏损为什么还继续
  • 银行存款利息收入要交税吗
  • 股东股权转让印花税 公司承担
  • 私营公司融资租房合法吗
  • mysql的安全级别
  • windowsold文件夹在哪里
  • windows sfc命令
  • ubuntu 添加开机启动
  • 将某软件添加到桌面
  • ubuntu安装sz
  • dllhost应用程序异常
  • windows8家庭版和专业版区别
  • win10系统自带的浏览器叫什么
  • sendmail -t
  • win8 系统设置
  • win8开始页面
  • cocos2d-x 3.4 windows 环境配置
  • javascript要怎么学
  • nodejs使用场景
  • 骨骼动画原理
  • 完美解决怠速抖动加油就平稳
  • vue使用jssdk
  • javascript程序设计教程
  • 关闭计算机盖的功能
  • python怎么处理json数据
  • 湖北税务登记办理流程和方法
  • 企业所得税季度申报时间
  • 国地税账号密码
  • 金三申报系统里面怎么申报社保?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设