Script de pagination de base de données PHP simple
Lorsque vous traitez de grandes quantités de données, la fonctionnalité de pagination est cruciale pour organiser et présenter efficacement les informations. Voici un script de pagination PHP facile à comprendre pour vous aider à accomplir cette tâche.
Concept de base :
Le script détermine le nombre total d'éléments dans la base de données puis calcule le nombre de pages nécessaires pour afficher tous les éléments en fonction de limites prédéfinies. Il calcule le décalage de la page en cours et affiche des informations sur la page en cours, telles que les numéros de ligne de début et de fin.
Exemple de mise en œuvre :
L'exemple de code suivant montre les scripts de pagination PHP en action :
<code class="language-php"><?php // 数据库连接和查询 $dbh = new PDO(...); $total = $dbh->query('SELECT COUNT(*) FROM table')->fetchColumn(); // 分页设置 $limit = 20; $pages = ceil($total / $limit); $page = min($pages, filter_input(INPUT_GET, 'page', FILTER_VALIDATE_INT, array( 'options' => array( 'default' => 1, 'min_range' => 1, ), ))); $offset = ($page - 1) * $limit; // 分页显示 $start = $offset + 1; $end = min(($offset + $limit), $total); $prevlink = ($page > 1) ? '<a href="?page=1">首页</a> <a href="?page=' . ($page - 1) . '">上一页</a>' : '« ‹'; $nextlink = ($page < $pages) ? '<a href="?page=' . ($page + 1) . '">下一页</a> <a href="?page=' . $pages . '">尾页</a>' : '› »'; echo "<div><p>此脚本根据数据库结果动态计算分页,提供了一种用户友好的方式,可以一次一页地浏览大型数据集。</p></div>"; echo "<div>显示{$start}到{$end}条记录,共{$total}条记录,共{$pages}页</div>"; echo "<div>{$prevlink} {$nextlink}</div>"; // 查询并显示分页数据 $stmt = $dbh->prepare("SELECT * FROM table LIMIT :limit OFFSET :offset"); $stmt->bindParam(':limit', $limit, PDO::PARAM_INT); $stmt->bindParam(':offset', $offset, PDO::PARAM_INT); $stmt->execute(); while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { // 显示数据 echo "<pre class="brush:php;toolbar:false">"; print_r($row); echo ""; } ?>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!