我正在为这段代码吃一段时间。在我继续之前,我真的不希望代码被重写,只是帮助我找到正确的方向,因为我迷路了^^
所以这是我用来查询列表的代码。$showitemsperlist 可以设置为我的用户,这表明每页应显示许多项目..
if (isset($_GET["page"]))
{
$page = $_GET["page"];
}
else
{
$page=1;
};
$start_from = ($page-1) * $showitemsperlist;
// THIS SECTION IS THE 'search' section. Items are shown according to user input.
if(isset($_POST['search']))
{
$search = $_POST['search'];
$terms = explode(" ", $search);
$customerlistquery = "
SELECT *
FROM customer
LEFT JOIN company
ON customer.compid=company.compid
WHERE
";
$i = 0;
foreach ($terms as $each)
{
if ($i++ > 0)
$customerlistquery .= ' OR ';
$customerlistquery .= "concat(custsurname, custforename, custmidname, custpostal, custphone1, custphone2, custfax, custnamecode) LIKE '%$each%' ";
}
$customerlistquery .= " ORDER BY $orderby ASC LIMIT $start_from, $showitemsperlist" ;
}
else
// IF NOT SEARCHING, JUST SHOW EVERYTHING.
{
$customerlistquery = "
SELECT *
FROM customer
LEFT JOIN company
ON customer.compid=company.compid
ORDER BY $orderby
ASC LIMIT $start_from, $showitemsperlist
";
}
// EXECUTE QUERY:
$result=mysql_query($customerlistquery) or die("query fout " . mysql_error() );
查询正常工作,但在此下面我使用这行代码来计算页面数:
$sql = "SELECT COUNT(custid) FROM customer";
$rs_result = mysql_query($sql);
$row = mysql_fetch_row($rs_result);
$total_records = $row[0];
$total_pages = ceil($total_records / $showitemsperlist);
echo "<p id='pagination'>";
if ($total_pages < 2)
{
echo "<br/>";
}
else
{
echo "Page: ";
for ($i=1; $i<=$total_pages; $i++)
{
echo "<a href='crm_custlist.php?page=".$i."' id='pagination'>".$i."</a>";
}
}
echo "</p>";
我在这里看到 1 个问题,即执行“搜索”功能时的 $sql。如果我没有执行“搜索”,我会得到页面链接,当我没有“搜索”时,我也会得到它们,因为它是静态的......不适合“搜索”查询。
所以我试图改变 $rs_result = mysql_query($sql); 到 ...($customerlistquery),因为它应该计算在那里找到的结果,但这给了我比它应该的更多的页面!
接下来我尝试将 fetch_row 更改为 num_rows,它返回 ASC 限制之间的差异,所以这没有帮助。
所以我需要计算总结果,不能是别的。
我真的不明白:
$sql = "SELECT COUNT(custid) FROM customer";
$rs_result = mysql_query($sql);
$row = mysql_fetch_row($rs_result);
$total_records = $row[0];
返回 27 个值。SELECT (custid) FROM customer 也返回 27 个值……所以我想通了。我需要以某种方式在 $customerlistquery 中有一个额外的 COUNT(custid) 字段,它返回总金额并且可以用作 $total_records。(至少我认为我想通了。)
最好的选择是 mysql_num_rows 返回找到的总记录,但由于 ASC LIMIT,现在这是不可能的......
我完全被困在这里。欢迎任何帮助!!!
谢谢。
编辑:31-10-2012 - 11:50
好的,我找到了。我需要对 $customerlistquery 使用 SELECT COUNT(*) 并将 ...($sql) 替换为:$rs_result = mysql_query($customerlistquery);。
这将返回我确实需要的值。但是现在我要回显的所有字段都是未定义的索引。
使用下面的这些行来定义索引...使用 SELECT ,而不是 SELECT COUNT( ):
while( $record=mysql_fetch_array($result) )
{
$custid=$record['custid'];
$compid=$record['compid'];
$compname=$record['compname'];
$custsurname=$record['custsurname'];
编辑:31-10-2012 - 12:06
现在非常接近!尝试将 COUNT(*) 的新表行添加到我的 $customerlistquery 中...尝试一切 ^^ 很快它将起作用...我希望。
SELECT *
FROM customer
LEFT JOIN company
ON customer.compid=company.compid
WHERE
( SELECT COUNT(*)
FROM customer )
不知道我在做什么,需要一点时间在评论变得无关紧要之前通知我的进展..