dtv8189 2014-09-15 15:14
浏览 66

PHP循环意外停止

I have a table (table3) in MYSQL with 99 text fields (field1, filed2, ...,field99). I wanted to count the non-empty values of each field so I wrote a simple php script with a for loop as below:

for($i = 1; $i <= 99; $i++)
{
  $sqlstm = "SELECT COUNT(field$i) FROM table3 WHERE field$i IS NOT NULL AND field$i <> '';";
  $r = @mysqli_query($dbc, $sqlstm);
  if($r)
  {
    while($row = @mysqli_fetch_array($r)) 
    {   
        echo "<p>$row[0]</p>
"; 
    }
  }
  else
  {
    echo "field $i error: " . mysqli_error($dbc);
  }
}

But the loop stopped after showing four values (field1 to filed4) and no error message. I do have all 99 fields with data in table3 and I could run the query manually for any field. Could this due to browser timeout? Can someone help me? Thanks.

  • 写回答

1条回答 默认 最新

  • dplm47571 2014-09-15 15:24
    关注
     $sqlstm = "SELECT COUNT(field$i) FROM table3
    

    you are selecting the columns here, your table has 99 rows but apperantly only 4 columns

    what you could better do is

    $sqlstm = "SELECT * FROM table3 WHERE (column name) IS NOT NULL";
    $count = 0
    for($sqlstm as $one) {
        $count = $count + 1;
    }
    echo($count);
    

    or something along those lines

    评论

报告相同问题?

悬赏问题

  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥15 帮我写一个c++工程