首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C:\wamp64\www中超过120秒的最大执行时间

C:\wamp64\www中超过120秒的最大执行时间
EN

Stack Overflow用户
提问于 2017-11-29 11:52:16
回答 2查看 2.2K关注 0票数 0

在C:\wamp64\www中超过120秒的最大执行时间。

我希望我的循环不是无限的。

代码语言:javascript
复制
if(isset($_POST['del']))
    {
        $id = $_GET['id'];
        $st = "Y";
            $stmtp = $user_home->runQuery('SELECT * FROM invoice WHERE BRN = :inv ORDER BY Sr ASC ');
    $stmtp->bindParam(':inv',$id);
    $stmtp->execute();
    $rowcd = $stmtp->fetch(PDO::FETCH_ASSOC); 
    if($stmtp->rowCount() > 0)
    {
    while($rowcd)
        {
            extract($rowcd);
        $stmtd = $user_home->runQuery('UPDATE invoice 
                                         SET State=:uname                                            
                                       WHERE Sr = :crn');
            $stmtd->bindParam(':crn',$Sr);
            $stmtd->bindParam(':uname',$st);
            $stmtd->execute();
        }
    }
    }

Select语句有5行。(有时它可能会少一些)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-11-29 12:09:00

这是一个无限的循环。

你在做:

代码语言:javascript
复制
$rowcd = $stmtp->fetch(PDO::FETCH_ASSOC);

然后评估它:

代码语言:javascript
复制
while($rowcd)

当它应该是:

代码语言:javascript
复制
while($rowcd = $stmtp->fetch(PDO::FETCH_ASSOC))

而不是两行

票数 0
EN

Stack Overflow用户

发布于 2017-11-29 12:08:35

bindParam()的用法来看,我假设您使用的是抽象到类中的PDO。

您只调用一次fetch(),它只返回一行,然后对其使用while语句。它永远不会在循环中得到更新,因此它总是计算为TRUE,从而继续循环。

要测试这一理论,可以在数组上运行一个简单的循环,该循环一直运行到断点:

代码语言:javascript
复制
<?php
while(array(1,2,3)){
    echo date('H:i:s');
}

我不完全确定$Sr变量来自何处,但根据第一个查询中的ORDER BY子句,它将在第一个查询中返回。

因此,每次都需要循环遍历并获取下一行,如下所示:

代码语言:javascript
复制
...
while ($row = $stmtp->fetch()) {
    $stmtd = $user_home->runQuery('UPDATE invoice 
                                         SET State=:uname                                            
                                       WHERE Sr = :crn');
    $stmtd->bindParam(':crn',$row['Sr']);
    $stmtd->bindParam(':uname',$st);
    $stmtd->execute();
}
...
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47552203

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档