PHP+Mysql 開発ページングで合計ページ数が表示される

総ページ数を表示

<html>
 <head>
     <meta http-equiv="CONTENT-TYPE" content="text/html;">
 </head>
 <body>
 <?php
 /** 1.传入页面 **/
 $page = $_GET['p'];
 /** 2.根据页面取出数据:php->mysql **/
 $host = "localhost";
 $username = 'root';
 $password = '123456789';
 $db = 'bbs2';
 $PageSize=5;
 //连接数据库
 $conn = mysql_connect($host, $username, $password);
 if(!$conn){
   echo "数据库连接失败";
     exit;
 }
 
 //选择所要操作的数据库
 mysql_select_db($db);
 //设置数据库编码格式
 mysql_query('SET NAMES UTF8');
 //编写sql获取分页数据:SELECT * FROM 表名 LIMIT 起始位置 , 显示条数
 $sql = "SELECT*FROM test LIMIT ".($page-1)*$PageSize .",$PageSize";
 if(!$sql){
     echo "取出不成功";
 };
 //把sql语句传送到数据库
 $result = mysql_query($sql);
 //处理我们的数据
 echo "<table border=1 cellspacing=0 width=15% >";
 echo "<tr><td>ID</td><td>名字</td><td>性别</td></tr>";
 while($row = mysql_fetch_assoc($result)){
     echo "<tr>";
     echo "<td>{$row['id']}</td>";
     echo "<td>{$row['name']}</td>";
     echo "<td>{$row['sex']}</td>";
     echo "<tr>";
 }
 
 //释放结果
 mysql_free_result($result);
 //获取数据总数
 $to_sql="SELECT COUNT(*)FROM test";
 $to_result=mysql_fetch_array(mysql_query($to_sql));
 $to=$to_result[0];
 //计算页数
 $to_pages=ceil($to/$PageSize);
 mysql_close($conn);
 /** 3.显示数据+分页条 **/
 $page_banner="<a href='".$_SERVER['PHP_SELF']."?p=".($page-1)."'>上一页</a>";
 $page_banner.="<a href='".$_SERVER['PHP_SELF']."?p=".($page+1)."'>下一页</a>";
 $page_banner.="共{$to_pages}页";
 echo $page_banner;
 ?>
 </body>
 </html>

コードの説明

//获取数据总数
 $to_sql="SELECT COUNT(*)FROM test";
 $to_result=mysql_fetch_array(mysql_query($to_sql));
 $to=$to_result[0];
 //计算页数
 $to_pages=ceil($to/$PageSize);
 mysql_close($conn);


この章の難しさ

$to_sql: データの総数を計算するために使用されます

$ to_result: 接続によって計算されます 総数を取得してデータを取得します

$to は取得されたアイテムの総数です

$to_pages ページ数を計算します $to/$PageSize それぞれに表示されるデータのページ数ページ、

ceil go up Integers なので、残りの数値も表示できます。

学び続ける
||
<html> <head> <meta http-equiv="CONTENT-TYPE" content="text/html;"> </head> <body> <?php /** 1.传入页面 **/ $page = $_GET['p']; /** 2.根据页面取出数据:php->mysql **/ $host = "localhost"; $username = 'root'; $password = '123456789'; $db = 'bbs2'; $PageSize=5; //连接数据库 $conn = mysql_connect($host, $username, $password); if(!$conn){ // echo "数据库连接失败"; exit; } //选择所要操作的数据库 mysql_select_db($db); //设置数据库编码格式 mysql_query('SET NAMES UTF8'); //编写sql获取分页数据:SELECT * FROM 表名 LIMIT 起始位置 , 显示条数 $sql = "SELECT*FROM test LIMIT ".($page-1)*$PageSize .",$PageSize"; if(!$sql){ echo "取出不成功"; }; //把sql语句传送到数据库 $result = mysql_query($sql); //处理我们的数据 echo "<table border=1 cellspacing=0 width=15% >"; echo "<tr><td>ID</td><td>名字</td><td>性别</td></tr>"; while($row = mysql_fetch_assoc($result)){ echo "<tr>"; echo "<td>{$row['id']}</td>"; echo "<td>{$row['name']}</td>"; echo "<td>{$row['sex']}</td>"; echo "<tr>"; } //释放结果 mysql_free_result($result); //获取数据总数 $to_sql="SELECT COUNT(*)FROM test"; $to_result=mysql_fetch_array(mysql_query($to_sql)); $to=$to_result[0]; //计算页数 $to_pages=ceil($to/$PageSize); mysql_close($conn); /** 3.显示数据+分页条 **/ $page_banner="<a href='".$_SERVER['PHP_SELF']."?p=".($page-1)."'>上一页</a>"; $page_banner.="<a href='".$_SERVER['PHP_SELF']."?p=".($page+1)."'>下一页</a>"; $page_banner.="共{$to_pages}页"; echo $page_banner; ?> </body> </html>
  • おすすめコース
  • コースウェアのダウンロード
現時点ではコースウェアはダウンロードできません。現在スタッフが整理中です。今後もこのコースにもっと注目してください〜