PHP while循环只迭代一次

时间:2012-05-22 10:51:31

标签: php loops while-loop iteration

快速问题;

$sql = mysql_query("SELECT * FROM cronjobs WHERE status = 0 ");

while($cronjob = mysql_fetch_array($sql)){
    if($cronjob['suid'] != $cronjob['cuid']){
        //echo 'not equal<br>';
        $set = 0;
        $sid = $cronjob['sid'];
        $suid = $cronjob['suid'];
        $cuid = $cronjob['cuid'];
        $set = notify($sid, $suid, $cuid);
        if($set==1){
            //echo 'notified<br>';
            $sql = "UPDATE cronjobs SET status = '1' WHERE id='".$cronjob['id']."'";
            if(mysql_query($sql)){
               echo '1<br>';
              $set = 0;
          }
        }
      }
   }
}

notify()return 1(数字)

问题是即使有更多记录,也会执行while循环的一次迭代。我不知道这里有什么问题。帮帮我吧。

3 个答案:

答案 0 :(得分:5)

请将内部$ sql变量名更改为其他内容.outer $ sql和内部变量名冲突

$sql = mysql_query("SELECT * FROM cronjobs WHERE status = 0 ");

while($cronjob = mysql_fetch_array($sql)){
    if($cronjob['suid'] != $cronjob['cuid']){
        //echo 'not equal<br>';
        $set = 0;
        $sid = $cronjob['sid'];
        $suid = $cronjob['suid'];
        $cuid = $cronjob['cuid'];
        $set = notify($sid, $suid, $cuid);
        if($set==1){
            //echo 'notified<br>';
            $sql_2 = "UPDATE cronjobs SET status = '1' WHERE id='".$cronjob['id']."'";
            if(mysql_query($sql_2)){
               echo '1<br>';
              $set = 0;
          }
        }
      }
   }
}

答案 1 :(得分:1)

只是观察:

因为你有:

$sql = mysql_query("SELECT * FROM cronjobs WHERE status = 0 ");  
while($cronjob = mysql_fetch_array($sql)){ 

它将执行查询每一次它经历循环。如果你有100行,它将执行100次。如果你这样做,那么它只执行一次。

$sql = mysql_query("SELECT * FROM cronjobs WHERE status = 0 ");  
$res = mysql_fetch_array($sql);
while($cronjob = $res){ 

它也不会发生冲突!

答案 2 :(得分:0)

当您具有相同的查询变量($ query)时,显然会发生此问题 和结果对象($ result)。在WHILE循环中为mysql_query()尝试使用不同的名称。

相关问题