Maison > base de données > tutoriel mysql > Comment implémenter une pagination PHP simple pour les résultats de la base de données ?

Comment implémenter une pagination PHP simple pour les résultats de la base de données ?

Mary-Kate Olsen
Libérer: 2025-01-21 19:01:11
original
321 Les gens l'ont consulté

How to Implement Simple PHP Pagination for Database Results?

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 "
"; } ?>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal