0

** 回答済み .. コンマの後に空白がありました。みんな、ありがとう!

次のコードを実行すると、すべての $castmember が表示されますが、mysql は最初のメンバーでのみ実行されます。

   $getactors=explode(",", $actors);
   foreach($getactors as $castmember){

     $idolid="";
     $srch3= "SELECT `id`,`dir` FROM `idols` WHERE `name`='$castmember'";
     $result5 = mysql_query($srch3);
     while ($row5 = mysql_fetch_assoc($result5)) {
     $idolid = $row5["id"];
     $idoldir= $row5["dir"];
     }

   if($idolid){ echo"<li style=\"font-size:1.2em;\" ><a href=\"/gallery/$idolid/$idoldir.html\" title=\"$castmember\" itemprop=\"actors\"> $castmember</a>";
     } else {
   echo"<li style=\"font-size:1.2em;\"><div style=\"display:inline\" itemprop=\"actors\"> $castmember</div>";
     }
   echo"<span></span></li>\n";
   }
4

1 に答える 1

1

explodeクエリをループで実行する必要はありません。IN句を使用できます。

 $srch3= "SELECT `id`,`dir` FROM `idols` WHERE `name` IN ('".$actors."')";

$actorsただし、これは、配列に有効な値がある場合にのみ機能します。

于 2013-02-15T19:59:10.070 に答える