php 分页
本文将介绍一种在 php 中使用 limit 子句和 sql
中的 select
语句在 php 中执行分页的方法。我们将使用 limit
子句选择从特定索引开始的特定行数以显示为分页。
我们还将演示另一种在 php 分页中添加 previous
和 next
导航功能的方法。此方法仅添加了将相应页面导航到第一种方法的附加功能。
在 php 中在 sql
中使用 limit
子句和 select
语句对行进行分页
我们可以使用 limit
子句和 select
语句来指定要在页面上显示的前 n 个结果。我们可以在 anchor
标签中提供页码作为 get
方法来浏览页面。在此方法中,我们定义每页要显示的行数,并从数据库中检索所有行以计算所需的总页数。我们可以使用 $_get
数组和 isset()
函数来获取用户请求的页码。
例如,创建一个变量 $results_per_page
并在其中存储 2
。使用 mysqli_num_rows()
函数查找数据库中的行数并存储在 $number_of_results
变量中。使用 ceil()
函数来确定显示行所需的总页数。将 $number_of_results
变量除以 ceil()
函数内的 $results_per_page
变量。使用 $_get
超全局变量和 isset()
函数来检查 page
变量是否已设置。如果尚未设置,请将 $page
变量设置为 1
。如果已设置变量,则将值分配给 $page
变量。用 1
减去 $page
变量并将其乘以 $this_page_first_result
变量。将操作存储在变量 $this_page_first_result
中。编写一个带有 limit
子句的 sql
语句为 select * from alpha limit ' . $this_page_first_result . ',' . $results_per_page.
运行查询并显示结果。最后,创建一个 for
循环以在 $page
变量和 $number_of_page
之间循环。在循环内,echo
anchor
标签并将 href
属性的值设置为 index.php?page'.$page
。在 anchor
标签之间写入 $page
变量。
在下面的示例中,数据库中的 alpha
表包含六行。执行分页后,每页显示两行。ceil()
函数确定显示行所需的总页数。最初,$page
变量未设置,因此页面从第 1 页开始。$this_page_first_result
变量确定用户当前所在的页码。变量 $this_page_first_result
表示页面的第一行。变量 $results_per_page
表示每页的结果数。输出部分显示 index.php
页面。当点击页面 2
时,它会从数据库中输出接下来的两行。
示例代码:
#php 7.x
php
$number_of_pages = ceil($number_of_results/$results_per_page);
if (!isset($_get['page'])) {
$page = 1;
} else {
$page = $_get['page'];
}
$this_page_first_result = ($page-1)*$results_per_page;
$sql='select * from alpha limit ' . $this_page_first_result . ',' . $results_per_page;
$result = mysqli_query($con, $sql);
while($row = mysqli_fetch_array($result)) {
echo $row['id'] . ' ' . $row['value']. '
';
}
for ($page=1;$page<=$number_of_pages;$page) {
echo ' ';
}
?>
输出:
1 a
2 b
1 2 3
在 php 的分页中添加 previous
和 next
导航功能
我们可以在第一种方法的代码示例中添加一些额外的代码片段,以在分页中提供 previous
和 next
导航功能。我们可以将 $page
变量递增和递减 1 以指向上一页和下一页。我们可以使用 anchor
标签中的递增和递减变量来实现 next
和 previous
功能。
例如,创建两个变量,$prev
和 $next
。用 1 减去 $page
变量并将操作分配给 $prev
变量。类似地,将 1 添加到 $page
变量并将其分配给 $next
变量。在页码的 for
循环之前回显一个 anchor
标签,上面写着 previous
。将 anchor
标签的 href
属性赋值为 index.php?page=' . $prev .
。以同样的方式,使用 $next
变量作为 href
属性中 page
的值,为 next
创建另一个 anchor
标记。
在下面的输出部分,它显示了第二页。单击 previous
进入第一页,单击 next
进入第三页。
示例代码:
# php 7.x
php
$prev = $page -1;
$next = $page 1;
echo ' ';
for ($page=1;$page<=$number_of_pages;$page) {
echo ' ';
}
echo ' ';
?>
输出:
3 c
4 d
previous 1 2 3 next
转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处
本文地址:
相关文章
如何在 php 中获取时间差的分钟数
发布时间:2023/03/29 浏览次数:204 分类:php
-
本文介绍了如何在 php 中获取时间差的分钟数,包括 date_diff()函数和数学公式。它包括 date_diff()函数和数学公式。
发布时间:2023/03/29 浏览次数:156 分类:php
-
本教程演示了如何将用户从页面重定向到 php 中的其他页面
发布时间:2023/03/29 浏览次数:128 分类:php
-
本文介绍如何在 php 中使用三元运算符作为 if else 的简写