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>
相关推荐
Zacks_xdc5 分钟前
【全栈】云服务器安装 MySQL + Next.js 连接完整 Demo
服务器·javascript·mysql·阿里云·nextjs·云服务器
gaozhiyong081327 分钟前
深度技术拆解:豆包2 Pro vs Gemini 3—国产工程派与海外原生派的巅峰对决
前端·spring boot·mysql
heze0943 分钟前
sqli-labs-Less-53
数据库·mysql·网络安全
LuckyTHP1 小时前
Centos7.9下 Mysql8.0 重置密码
mysql
whuhewei2 小时前
在React中实现CSS动画的回放
前端·css·react.js
liuxin_07253 小时前
vscode cursor
php
yoyo_zzm3 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
桌面运维家3 小时前
KVM虚拟机:Neutron网络故障诊断与修复实战
服务器·网络·php
数据库小组4 小时前
Oracle 上云 / 替代场景下,NineData 完成到 PostgreSQL 的低风险迁移
大数据·数据库·mysql·postgresql·oracle·数据一致性·数据库迁移
hzb666664 小时前
xd_day32-day40
java·javascript·学习·安全·web安全·tomcat·php