php实现一个简单的MySQL分页

一、案例演示:

二、php 代码

bash 复制代码
<?php
$servername = "localhost";  // MySQL服务器名称或IP地址  
$username = "root";     // MySQL用户名  
$password = "123456";     // MySQL密码  
$dbname = "test";       // 要连接的数据库名称  
$port = "3307";       // 要连接的数据库名称  

// 创建连接  
$dbc = new mysqli($servername, $username, $password, $dbname, $port);

// 检查连接是否成功  
if ($dbc->connect_error) {  
    die("连接失败: " . $dbc->connect_error);  
}  
?>

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>分页</title>
    <link rel="stylesheet" href="./css/bootstrap.min.css">
    <script src="./js/jquery.min.js"></script>
    <script src="./js/bootstrap.min.js"></script>
    <style>
        body {
            width: 100%;
            overflow: hidden;
            background: url("background.jpeg") no-repeat;
            background-size: cover;
        }
        .table-container {
            width: 80%;
            margin: 0 auto;
        }
        table {
            width: 100%;
            border-collapse: collapse;
            background-color: white;
        }
        th, td {
            border: 1px solid black;
            padding: 8px;
            text-align: center;
        }
        th {
            background-color: #f2f2f2;
        }
        .pagination {
            display: flex;
            justify-content: center;
        }
    </style>
</head>

<body>
    
    <h1 style="text-align: center"><strong>分页</strong></h1>
    <div class="table-container">
        <table class="table table-hover">
            <tr>
                <th>id</th>
                <th>姓名</th>
            </tr>
            <?php
                // 定义每页显示的记录数
                $pageSize = 10;

                // 获取当前页码,默认为第一页
                $page = isset($_GET['page']) ? intval($_GET['page']) : 1;

                // 计算当前页码对应的记录偏移量
                $offset = ($page - 1) * $pageSize;

                $sql = "SELECT * FROM page order by id asc LIMIT $offset, $pageSize";

                $res = mysqli_query($dbc, $sql);
                // 计算总记录数
                $totalSql = "SELECT COUNT(*) AS total FROM page";
                $totalResult = mysqli_query($dbc, $totalSql);
                $totalRow = mysqli_fetch_assoc($totalResult);
                $total = $totalRow['total'];

                // 计算总页数
                $totalPages = ceil($total / $pageSize);

                foreach ($res as $row) {
                    echo "<tr>";
                    echo "<td>{$row['id']}</td>";
                    echo "<td>{$row['name']}</td>";
                    echo "</tr>";
                }
            ?>
        </table>
    </div>
    <div style="text-align: center; margin-top: 20px;">
        <ul class="pagination">
            <?php
            // 生成分页链接
            for ($i = 1; $i <= $totalPages; $i++) {
                // 根据当前页添加特殊样式
                $activeClass = ($i == $page) ? 'active' : '';
                echo "<li class='$activeClass'><a href='index.php?page=$i'>$i</a></li>";
            }
            ?>
        </ul>
    </div>
</body>

</html>
相关推荐
远洪1 小时前
claude code 国内安装使用
数据库·mysql
wangbing11253 小时前
MySQL 官方 GPG 密钥过期问题
数据库·mysql
重生之我是Java开发战士3 小时前
【MySQL】事务 & 用户与权限管理
android·数据库·mysql
2401_895521344 小时前
MySQL中的count函数
数据库·mysql
zx2859634004 小时前
Laravel 8.x 核心特性全面解析
php·laravel
.小小陈.4 小时前
MySQL 入门到实战:从基础概念到核心存储引擎
数据库·mysql
yoyo_zzm5 小时前
Laravel10.x新特性全解析
数据库·mysql·架构
yqcoder5 小时前
端经典面试题:为什么 0.1 + 0.2 !== 0.3?
前端·css
ZC跨境爬虫5 小时前
跟着 MDN 学 HTML day_12:(HTML网页图片嵌入)
前端·javascript·css·ui·html
用户059540174465 小时前
大模型记忆存储踩坑实录:LangChain 的 ConversationBufferMemory 让我排查了 6 小时
前端·css