PHPでページング表示を実装する方法

墨辰丷
リリース: 2023-03-30 07:36:01
オリジナル
2414 人が閲覧しました

この記事では主にPHPでページング表示を実現する方法を紹介しますので、興味のある方は参考にしていただければ幸いです。

いわゆるページング表示とは、データベース内の結果セットを表示のために人為的にセクションに分割することを意味します:

1 ページあたりのレコード数 ($PageSize)。

現在どのページ ($CurrentPageID) にありますか?

今度は別の結果セットを与えるだけで、特定の結果を表示できます。
他のパラメータについては、前のページ ($PReviousPageID)次のページ ($NextPageID)総ページ数 ($numPages) など、事前の知識に基づいて取得できます。 。

MySQL データベースを例に挙げると、テーブルから特定のコンテンツをインターセプトしたい場合は、SQL ステートメントを使用できます: select * from table limit offset, rows。次の一連の SQL ステートメントを見て、ルールを見つけてください。

最初の 10 レコード: select * from table limit 0,10

11 番目から 20 番目のレコード: select * from table limit 10,10

21 番目から 30 番目のレコード: select * from table limit 20,10

...

この SQL ステートメントのセットは、実際には、$PageSize=10 の場合にテーブルの各ページからデータをフェッチする SQL ステートメントです。このようなテンプレートを要約できます:

select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
ログイン後にコピー

Useこのテンプレートを使用して対応する値を置き換え、それを上記の一連の SQL ステートメントと比較して、該当するかどうかを確認します。データを取得する方法という最も重要な問題を解決したら、あとはパラメータを渡し、適切な SQL ステートメントを作成し、PHP を使用してデータベースからデータを取得して表示するだけです。以下、具体的なコードを用いて説明していきます。
簡単なコード実装
次のコードを詳しく読んで、自分でデバッグして実行してください。一度変更して、検索などの独自の機能を追加するのが最善です。

// 建立数据库连接 
$link = mysql_connect("localhost", "mysql_user", "mysql_passWord")  
   or die("Could not connect: " . mysql_error());  
// 获取当前页数 
if( isset($_GET['page']) ){ 
  $page = intval( $_GET['page'] ); 
} 
else{ 
  $page = 1; 
}  
// 每页数量 
$PageSize = 10;  
// 获取总数据量 
$sql = "select count(*) as amount from table"; 
$result = mysql_query($sql); 
$row = mysql_fetch_row($result); 
$amount = $row['amount'];  
// 记算总共有多少页 
if( $amount ){ 
  if( $amount < $page_size ){ $page_count = 1; }        //如果总数据量小于$PageSize,那么只有一页 
  if( $amount % $page_size ){                 //取总数据量除以每页数的余数 
    $page_count = (int)($amount / $page_size) + 1;      //如果有余数,则页数等于总数据量除以每页数的结果取整再加一 
  }else{ 
    $page_count = $amount / $page_size;           //如果没有余数,则页数等于总数据量除以每页数的结果 
  } 
} 
else{ 
  $page_count = 0; 
} 
// 翻页链接 
$page_string = &#39;&#39;; 
if( $page == 1 ){ 
  $page_string .= &#39;第一页|上一页|&#39;; 
} 
else{ 
  $page_string .= &#39;第一页|.($page-1).&#39;>上一页|&#39;; 
}  
if( ($page == $page_count) || ($page_count == 0) ){ 
  $page_string .= &#39;下一页|尾页&#39;; 
} 
else{ 
  $page_string .= &#39;.($page+1).&#39;>下一页|.$page_count.&#39;>尾页&#39;; 
} 
// 获取数据,以二维数组格式返回结果 
if( $amount ){ 
  $sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size"; 
  $result = mysql_query($sql); 
  while ( $row = mysql_fetch_row($result) ){ 
    $rowset[] = $row; 
  } 
}else{ 
  $rowset = array(); 
} 
// 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果 
?>
ログイン後にコピー

要約: 以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。

関連する推奨事項:

PHP で階層ツリー展開を再帰的に実装する方法

PHP 関数 import_request_variables() の使用法と分析例

配列内の値の合計と積を計算する PHP メソッド分析例

以上がPHPでページング表示を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート