0
function addAds($n) {
 for ($i=0;$i<=$n;$i++) {
  while($row=mysql_fetch_array(mysql_query("SELECT * FROM users"))) {
   $aut[]=$row['name'];
  }
  $author=$aut[rand(0,mysql_num_rows(mysql_query("SELECT * FROM users")))];
  $name="pavadinimas".rand(0,3600);
  $rnd=rand(0,1);
  if($rnd==0) {
   $type="siulo";
  } else {
   $type="iesko";
  }
  $text="tekstas".md5("tekstas".rand(0,8000));
  $time=time()-rand(3600,86400);
  $catid=rand(1,9);
  switch ($catid) {
   case 1:
    $subid=rand(1,8);
    break;
   case 2:
    $subid=rand(9,16);
    break;
   case 3:
    $subid=rand(17,24);
    break;
   case 4:
    $subid=rand(25,32);
    break;
   case 5:
    $subid=rand(33,41);
    break;
   case 6:
    $subid=rand(42,49);
    break;
   case 7:
    $subid=rand(50,56);
    break;
   case 8:
    $subid=rand(57,64);
    break;
   case 9:
    $subid=rand(65,70);
    break;
  }
  mysql_query("INSERT INTO advert(author,name,type,text,time,catid,subid) VALUES('$author','$name','$type','$text','$time','$catid','$subid')") or die(mysql_error());
 }
 echo "$n adverts successfully added.";
}

这个函数的问题是它永远不会加载。正如我所注意到的,我的 while 循环导致了它。如果我评论它,一切都好。它必须从我的数据库中获取随机用户并将其设置为变量 $author。

4

6 回答 6

6

问题是查询在循环中,所以它每次都会运行(所以你每次都从头开始)。只需将 mysql_query() 部分移动到 while 循环之前的右侧并将其存储在变量中:

$query = mysql_query("SELECT * FROM users");
while($row=mysql_fetch_array($query))
于 2010-05-30T22:17:41.607 回答
4

您可以用一条线替换这个巨型开关:

$subid = rand(($catid * 8) - 7, min($catid * 8, 70));
于 2010-05-30T22:22:27.190 回答
2

我还认为问题在于您的功能太大而无法理解(很快)。您应该使它们更小,并使用 phpunit 之类的单元测试框架对其进行测试。

于 2010-05-30T22:24:25.710 回答
2

while每次迭代都会执行和评估循环的条件。每次迭代都会调用somysql_query并且返回 true。

只需执行一次数据库查询并缓存结果:

function addAds($n) {
    $result = mysql_query("SELECT * FROM users");
    $aut = array();
    while ($row = mysql_fetch_array($result)) {
        $aut[]=$row['name'];
    }
    $rowCount = count($aut);
    for ($i=0; $i<=$n; $i++) {
        $author=$aut[rand(0,$rowCount)];
        // …
        mysql_query("INSERT INTO advert(author,name,type,text,time,catid,subid) VALUES('$author','$name','$type','$text','$time','$catid','$subid')") or die(mysql_error());
    }
    echo "$n adverts successfully added.";
}
于 2010-05-30T22:18:17.273 回答
1

我有很多时间不使用 PHP,但我认为分配

$row=mysql_fetch_array(mysql_query("SELECT * FROM users"))

应该总是返回true,它在每次迭代中一次又一次地执行查询。

于 2010-05-30T22:18:32.690 回答
0

每次运行循环时,您都会开始一个新查询。

于 2010-05-30T22:17:46.513 回答