mysql 데이터베이스에 정렬 된 순서로 액세스하는 PHP 코드를 테이블에 인쇄합니다. 그러나 mysql_fetch_array를 호출 할 때마다 함수는 아무것도 반환하지 않습니다. mysql_num_rows가 4인데도 아무 것도 반환하지 않습니다. 즉, $ row = 'mysql_fetch_array ($ result);를 수행하면 $ row ['name ']은 테이블의 이름 열. 코드 스 니펫은 다음과 같습니다.mysql_num_rows가 PHP에서 4를 반환하는 동안 mysql_fetch_array는 아무 것도 반환하지 않습니다.
<?php
include_once("include.php");
$number=0;
if(!isset($_GET['scores'])) {
$number=10;
}
else if((int)$_GET['scores']>100) {
$number=100;
}
else if((int) $_GET['scores']<0) {
$number=10;
}
else {
$number=(int) $_GET['scores'];
}
$con=mysql_connect($dbhost, $dbuser, $dbpass);
mysql_select_db($dbname, $con);
$result=mysql_query("SELECT * FROM ".$dbtable_scores." ORDER BY score DESC,date;", $con);
$num=1;
echo("<table>");
echo("<tr><td>position</td><td>Name</td><td>score</td><td>date</td></tr>");
while($row=mysql_fetch_array($result) && $num<=$number) {
echo("<tr>");
echo("<td>".$num."</td>");
echo("<td>".$row['name']."</td><td>".$row['score']."</td><td>".$row['date']."</td>");
echo("</tr>");
$num++;
}
echo("</table>");
mysql_close($con);
?>
mysql cli에서 쿼리를 검사했는데 제대로 작동하는 것 같습니다. 그러나 http://mtgames.org/index.php으로 가면 테이블에 mysql에서 생성되지 않은 숫자 만 표시됩니다. mysql 테이블에는 이름, 점수, 날짜 등이있다. 도움을 주시면 감사하겠습니다. 감사합니다. - 마이클.
코드를 포맷 할 수 있습니까? 코드를 선택하고'{}'버튼을 누르면됩니다. – Nemoden
'&& $ num <= $ number' 왜이 부분이 필요합니까? – zerkms
while 루프를 시작한 후에 var_dump ($ row)를 수행하고 출력을 표시 할 수 있습니까? – bumperbox