Я создаю страницу для тех, у кого будет отображаться все заказы в базе данных, ограниченные до 10 на страницу.Проблема с обнаружением количества страниц на основе итоговых результатов запроса
Он работает с этой целью, но теперь проблема, когда я пытаюсь получить максимальное количество страниц, используя следующий код:
$msql = "SELECT * FROM orders";
$mresult = $db->query($msql);
if(is_object($mresult) && $mresult->num_rows > 0)
{
if($mresult->num_rows > 10)
{
$maxpage = $mresult->num_rows/10 + 1;
}
else
{
$maxpage = 1;
}
}
Это не установит переменную $ maxpage ни к чему, кроме 1, если в базе данных не зарегистрировано 20 или более заказов.
Сейчас у меня есть 11 тестовых заказов в базе данных, поэтому, когда он делит на 10, он должен установить максимальные страницы на 1, + 1 дополнительную страницу, так как существует более 10 заказов.
Я прочесал сеть, ища решение, и подошел с пустыми руками. Любые мысли или предложения?
EDIT:
Добавлен код в нижней части таблицы фактические заказы отображаются для дальнейшего поиска неисправностей:
<tr>
<td colspan="2" align="left"><a href="orders?start=<?php if($page == 1) { echo 0; } else { echo $start - 10; } ?>&page=<?php if($page == 1) { echo 1; } else { echo $page - 1; } ?>"><<<<</a> Prev</td>
<td align="center">Page <?php if(isset($_GET['page'])) { echo $_GET['page'] . ' of ' . $maxpage; } else { echo '1 of 1'; } ?></td>
<td colspan="2" align="right">Next <a href="orders?start=<?php if($page <= $maxpage) { echo 0; } else { echo $start + 10; } ?>&page=<?php if($page < $maxpage) { echo $page + 1; } else { echo $page; } ?>">>>>></a></td>
</tr>
'(11/10 + 1)' 'это в PHP 2', насколько как я знаю. На самом деле я не вижу в вашей логике ничего плохого. –
Возможный дубликат [Найти общее количество результатов в mySQL-запросе со смещением + лимит] (http://stackoverflow.com/questions/5928611/find-total-number-of-results-in-mysql-query-with-offsetlimit) – CBroe