使用 MySQL LIMIT、OFFSET 进行分页:动态页面创建
分页允许用户通过每页显示有限数量的项目来导航大型数据集。通过利用 MySQL LIMIT 和 OFFSET 子句,我们可以有效地检索特定页的数据。
但是,为每个潜在页码创建单独的页是低效的。相反,我们可以根据数据库中的总行数动态确定页数。
确定页数
查找总页数页,我们必须首先使用单独的查询计算表中的总行数。
SELECT COUNT(*) FROM menuitem
这将返回带有包含总行数的列。
计算页数
然后,我们可以通过将总行数除以每页所需的项目并四舍五入来计算总页数直到最接近的整数。
$page_count = (int)ceil($row_count / $items_per_page);
调整无效页面请求
当用户请求不存在的页面时(例如,只有3个页面时,请求第5页),我们可以根据情况将其重定向到最后一页或第一页.
输出页面链接
一旦我们知道了总页数,我们可以生成页面链接列表。对于当前页面,我们将其显示为文本,而对于其他页面,我们创建指向它们的链接。
for ($i = 1; $i <= $page_count; $i++) { if ($i === $page) { // current page echo 'Page ' . $i . '<br>'; } else { // link to other page echo '<a href="/menuitem.php?page=' . $i . '">Page ' . $i . '</a><br>'; } }
修订代码
使用动态页面计算方法,修改后的代码可能如下所示:
// Get page number from URL $page = 1; if (!empty($_GET['page'])) { $page = filter_input(INPUT_GET, 'page', FILTER_VALIDATE_INT); if (false === $page) { $page = 1; } } // Get total row count $sql = "SELECT COUNT(*) FROM menuitem"; $result = mysqli_query($con, $sql); $row_count = mysqli_num_rows($result); mysqli_free_result($result); // Calculate page count $page_count = (int)ceil($row_count / $items_per_page); // Double check page is in range if ($page > $page_count) { $page = 1; } // Calculate offset $offset = ($page - 1) * $items_per_page; // Select limited data $sql = "SELECT * FROM menuitem LIMIT " . $offset . "," . $items_per_page; $result = mysqli_query($con, $sql); // ... (Rest of your code) ... // Output page links for ($i = 1; $i <= $page_count; $i++) { if ($i === $page) { echo 'Page ' . $i . '<br>'; } else { echo '<a href="/menuitem.php?page=' . $i . '">Page ' . $i . '</a><br>'; } }
此代码允许您根据页面数量动态创建页面数据库中的行,无需硬编码页码和偏移量。
以上是如何在MySQL中使用LIMIT和OFFSET动态生成分页链接?的详细内容。更多信息请关注PHP中文网其他相关文章!