我在修改php应用程序有分页时遇到了问题。我的错误似乎与我的逻辑有关,而且我不清楚我做错了什么。我以前有过,但目前没有收到mysql_num_rows()无效结果资源 的错误,并且提供了无效参数给foreach。我认为在我的逻辑中存在一个问题,它会阻止mysql返回的结果。php和mysql没有显示数据,没有进入foreach循环
我所有的“测试”回声都是输出,除了循环测试。使用查询名称和词拍卖以及第一个和上一个链接生成页面,但不会生成下一个和最后一个链接。如果可以指出一个更有效的方式来生成表格中的行的链接,而不是每个单元格都建立链接,我将不胜感激。是否有可能有多个项目的连续链接?
<?php
if (isset($_GET["cmd"]))
$cmd = $_GET["cmd"]; else
die("You should have a 'cmd' parameter in your URL");
$query ='';
if (isset($_GET["query"])) {
$query = $_GET["query"];
}
if (isset($_GET["pg"]))
{
$pg = $_GET["pg"];
}
else $pg = 1;
$con = mysql_connect("localhost","user","password");
echo "test connection<p>";
if(!$con) {
die('Connection failed because of' .mysql_error());
}
mysql_query('SET NAMES utf8');
mysql_select_db("database",$con);
if($cmd=="GetRecordSet"){
echo "test in loop<p>";
$table = 'SaleS';
$page_rows = 10;
$max = 'limit ' .($pg - 1) * $page_rows .',' .$page_rows;
$rows = getRowsByProductSearch($query, $table, $max);
echo "test after query<p>";
$numRows = mysql_num_rows($rows);
$last = ceil($rows/$page_rows);
if ($pg < 1) {
$pg = 1;
} elseif ($pg > $last) {
$pg = $last;
}
echo 'html stuff <p>';
foreach ($rows as $row) {
echo "test foreach <p>";
$pk = $row['Product_NO'];
echo '<tr>' . "\n";
echo '<td><a href="#" onclick="updateByPk(\'Layer2\', \'' . $pk . '\')">'.$row['USERNAME'].'</a></td>' . "\n";
echo '<td><a href="#" onclick="updateByPk(\'Layer2\', \'' . $pk . '\')">'.$row['shortDate'].'</a></td>' . "\n";
echo '<td><a href="#" onclick="updateByPk(\'Layer2\', \'' . $pk . '\')">'.$row['Product_NAME'].'</a></td>' . "\n";
echo '</tr>' . "\n";
}
if ($pg == 1) {
} else {
echo " <a href='{$_SERVER['PHP_SELF']}?pg=1'> <<-First</a> ";
echo " ";
$previous = $pg-1;
echo " <a href='{$_SERVER['PHP_SELF']}?pg=$previous'> <-Previous</a> ";
}
echo "---------------------------";
if ($pg == $last) {
} else {
$next = $pg+1;
echo " <a href='{$_SERVER['PHP_SELF']}?pg=$next'>Next -></a> ";
echo " ";
echo " <a href='{$_SERVER['PHP_SELF']}?pg=$last'>Last ->></a> ";
}
echo "</table>\n";
}
echo "</div>";
function getRowsByProductSearch($searchString, $table, $max) {
$searchString = mysql_real_escape_string($searchString);
$result = mysql_query("SELECT Product_NO, USERNAME, ACCESSSTARTS, Product_NAME, date_format(mycolumn, '%d %m %Y') as shortDate FROM {$table} WHERE upper(Product_NAME) LIKE '%" . $searchString . "%'" . $max);
if($result === false) {
echo mysql_error();
}
$rows = array();
while($row = mysql_fetch_assoc($result)) {
echo "test while <p>";
$rows[] = $row;
}
return $rows;
mysql_free_result($result);
}
编辑:我已经打印出其中没有的mysql错误。然而,从包含超过100条记录的数据库打印出8个“测试时间”。 foreach循环从来没有被入侵过,我不确定为什么。
你的代码在很多方面都被破坏了。请查看SQL注入和HTML实体等主题(提示:如果您希望显示字面意思是“<”,则几乎肯定需要写<代替)。除此之外,请尝试将您的问题修剪至要点。删除评论和无关代码 – phihag 2009-02-02 12:59:00
这与我的问题无关。我正在将我所有的代码转换为mysqli来解决这个问题。我不知道什么代码导致了中断,所以我不知道要删除什么。 – 2009-02-02 13:07:20
如果它从不运行foreach,那么它可能意味着$行是空的,也许呢?也许getRowsByProductSearch不是你所期望的? – Ben 2009-02-02 19:32:36