欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

循环执行一个操作,循环次数太多,执行次数太长导致错误,怎么优化?

程序员文章站 2024-02-17 16:14:10
...
代码大概是这样的:
    public function test(){
        for ($i=0; $i 

大概查10个数据左右,就会出现:
Fatal error: Maximum execution time of 30 seconds exceeded in xxxx

有没有什么比较好的办法让他一边运行一边输出结果(现在是运行完一下子出现数据和上述错误),而不会出现因为运行时间过长产生错误呢?

回复内容:

代码大概是这样的:

    public function test(){
        for ($i=0; $i 

大概查10个数据左右,就会出现:
Fatal error: Maximum execution time of 30 seconds exceeded in xxxx

有没有什么比较好的办法让他一边运行一边输出结果(现在是运行完一下子出现数据和上述错误),而不会出现因为运行时间过长产生错误呢?

我勒去,这个什么业务逻辑啊!如果 findappbyid 查数据库的话,纯粹是看数据库不爽啊

ob_end_flush();
ob_implicit_flush(true);
for ($i=0; $i 
                            
            

php的配置里默认的执行时间是30秒,30秒对于一般的也足够了。

你可以在你的程序里添加set_time_limit(3600)临时改变程序的执行时间。
或者ini_set("max_execution_time", "3600")

如果你的是本地测试的机器,也可以将php.ini中的max_execution_time = 30中的30改成3600,或者更大的数,然后重启服务。

可以建立一个阻塞队列,把循环的次数变成队列的长度,单次执行的放到队列的节点中去做

相关标签: php mysql