ホームページ php教程 php手册 ページング表示の詳しい説明

ページング表示の詳しい説明

Jun 21, 2016 am 09:07 AM
gt page quot this

ページング|表示|詳しい説明

1. はじめに

ページング表示は、大量のデータを参照して表示する非常に一般的な方法であり、Web プログラミングで最も一般的に処理されるイベントの 1 つです。 Web プログラミングのベテランにとって、この種のコードを書くのは呼吸するのと同じくらい自然なことですが、初心者にとってはこの問題について混乱することが多いため、この問題を詳しく説明するために特別にこの記事を書き、読者の友人に知ってもらえるよう努めています。この記事を読み終えると、ページング表示の原理と実装方法がある程度理解できるようになります。この記事は初心者が読むのに適しており、すべてのサンプル コードは PHP で書かれています。

2. 原則

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

1 ページあたりのレコード数 ($PageSize)。
現在どのページにありますか ($CurrentPageID)?

これで、別の結果セットを提供していただければ、特定の結果を表示できます。
前のページ ($PreviousPageID)、次のページ ($NextPageID)、総ページ数 ($numPages) などの他のパラメーターについては、すべて前述の内容に基づいて取得できます。
mysql データベースを例に挙げると、テーブルから特定のコンテンツを取得したい場合は、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 ステートメントです。このようなテンプレートを要約すると、次のようになります。

このテンプレートを使用して、対応する値を挿入し、上記の一連の SQL ステートメントと比較して、該当するかどうかを確認してください。データを取得する方法という最も重要な問題を解決したら、あとはパラメータを渡し、適切な SQL ステートメントを作成し、PHP を使用してデータベースからデータを取得して表示するだけです。以下、具体的なコードを用いて説明していきます。

3. シンプルなコード
以下のコードを詳しく読んで、自分でデバッグして実行して、検索などの独自の機能を追加することをお勧めします。

//データベース接続を確立します
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("接続できませんでした: " .mysql_error());
// Get現在のページ番号
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 未満の場合、ページは 1 つだけです
if( $amount % $page_size ){ // 合計データ量をページ数で割った余り
$page_count = (int)($amount / $page_size) + 1; // ページ数は、合計データ量をページ数で割って切り上げて 1 を加えた値になります
}else{
$page_count = $amount / $page_size; //余りがない場合、ページ数はデータ量を1ページあたりのページ数で割った結果となります
}
}
else{
$ page_count = 0;
}

// ページめくりリンク
$page_string = '';
if( $page == 1 ){
$ page_string .= '最初のページ|前のページ|';
}
else{
$page_string .= '最初のページ|前のページ|' ;
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= '次のページ|最後のページ';
}
else{
$page_string .= '< ;a href=?page='.($page+1).'>次のページ|最後のページ';
}
// データを取得し、結果を 2 次元配列形式で返します
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 を使用するだけで簡単に結果を表示できます。

4. OO スタイル コード
次のコードのデータベース接続は、pear db クラスを使用して処理されます

// ファイル名: Pager.class.php
//このクラスは次の目的でのみ使用されます。プロセスデータ構造。表示作業を担当しません
Class Pager
{
var $PageSize //各ページの番号
var $CurrentPageID; //現在のページ数
var $NextPageID; //次のページ
var $PreviousPageID; // 前のページ
var $numPages; // レコードの総数
var $isFirstPage;最初のページ
var $isLastPage; //最後のページかどうか
var $sql; //SQL クエリ文

function Pager($option)
{
global $db;
$this->_setOptions($option) );
// アイテムの総数
if ( !isset($this->numItems) )
{
$res = $db->query($this->sql);
$this-> numItems = $res- >numRows();
}
// 総ページ数
if ( $this->numItems > 0 )
{
if ( $this->numItems < $this-> ;PageSize ){ $this ->numPages = 1; }
if ( $this->numItems % $this->PageSize )
{
$this->numPages= (int)($this-> numItems / $this->PageSize) + 1;
}
else
{
$this->numPages = $this->numItems / $this->PageSize;
}
}
else
{
$ this->numPages = 0;
}

switch ( $this->CurrentPageID )
{
case $this->numPages == 1:
$this->isFirstPage = true;
$this-> ;isLastPage = true;
Break;
case 1:
$this->isFirstPage = true;
$this->isLastPage = false;
Break;
case $this->numPages:
$this-> isFirstPage = false;
$ this->isLastPage = true;
Break;
デフォルト:
$this->isFirstPage = false;
$this->isLastPage = false;
}

if ( $this-> ;numPages > 1 )
if ( !$this->isLastPage ) { $this->NextPageID = $this->CurrentPageID + 1 }
if ( !$this->isFirstPage ) { $ this->PreviousPageID = $this->CurrentPageID - 1; }
}

return true;
}

/***
*
* 結果セットのデータベース接続を返します
* 結果セットが比較的大きい場合、このメソッドを直接使用してデータベース接続を取得し、クラスの外をトラバースできるため、オーバーヘッドが小さくなります
*結果セットはそれほど大きくないため、getPageData を直接使用して 2 次元配列形式で結果を取得できます
* getPageData メソッドもこのメソッドを呼び出して結果を取得します
*
***/

function getDataLink()
{
if ( $this-> ;numItems )
{
global $db;

$PageID = $this->CurrentPageID;

$from = ($PageID - 1)*$this->PageSize;
$count = $this-> PageSize;
$link = $db->limitQuery($this->sql, $from, $count); //Pear DB::limitQuery メソッドを使用してデータベースの互換性を確保します

return $link;
}
else
{
return false
}
}

/***
*
* 結果セットを 2 次元配列の形式で返します
*
***/

function getPageData()
{
if ( $this->numItems )
{
if ( $res = $this-> ;getDataLink() )
{
if ( $res->numRows() )
{
while ( $row = $res->fetchRow() )
{
$result[] = $row;
}
}
else
{
$result = array();
}

return $result;
}
else
{
return false;
}
}
else
{
return false;
}
}

関数_setOptions($option)
{
$allow_options = array(
'PageSize',
'CurrentPageID',
'sql',
'numItems'
);

foreach ( $option as $key => $value )
{
if ( in_array ($key, $allow_options) && ($value != null) )
{
$this->$key = $value;
}
}

return true;
}
}
?>
< ?php
// ファイル名: test_pager.php
// これは簡単なサンプルコードです。pear db クラスを使用してデータベース接続を確立するコードは省略されています
require "Pager.class.php";
if ( isset($_GET['page']) )
{
$ page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from table order by id"; "sql " => $sql,
"ページサイズ" => 10,
"現在のページID" => $page
);
if ($_GET['numItems'])
{
$pager_option[' numItems '] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option)
$data = $pager->getPageData(); isFirstPage )
{
$turnover = "ホーム|前のページ|";
}
else
{
$turnover = "|前のページ
}
if ( $pager->isLastPage )
{
$turnover .= "次のページ|最後のページ";
}
else
{
$turnover .= "次のページ|最後のページ";
}
?>


説明する必要があることが 2 つあります:

このクラスはデータのみを処理し、データ処理と結果表示を一つのクラスに入れるのはちょっと抵抗があると思うので、処理表示は担当しません。表示する場合、状況や要件が変更される可能性があるため、Pager クラスをベースにして独自のサブクラスを継承して、別のページネーションを表示することをお勧めします。ユーザー ページネーション リストは次のことができます:

< ;?php
Class MemberPager extends Pager
{
function showMemberList()
{
global $db;

$data = $this->getPageData();
// コード結果を表示します
// .... ..
}
}
///
if ( isset($_GET['page']) ) を呼び出します
{
$page = (int)$_GET['page' ];
}
else
{
$ page = 1;
}
$sql = "ID 順にメンバーから * を選択";
$pager_option = array(
"sql" => $sql,
"PageSize" => 10,
"現在のページID" = > $page
);
if (isset($_GET['numItems']) )
$pager_option['numItems'] = (int)$_GET['numItems '];
}
$pager = @ new MemberPager($pager_option);
$pager->showMemberList();
?>


説明する必要がある 2 番目の点は、異なるデータベースの互換性です。結果のセクションを異なるデータベースに同じように書き込む方法はありますか?
mysql: select * from table limit offset, rows
pgsql: select * from table limit m offset n
......
そのため、クラス内の結果を取得したい場合は、次の limitQuery メソッドを使用する必要があります。 pear db クラス。

わかりました。読み終わったら、私の功績とさせていただきます。時間をかけてこの言葉を読んでいただければ幸いです。





このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Huawei GT3 ProとGT4の違いは何ですか? Huawei GT3 ProとGT4の違いは何ですか? Dec 29, 2023 pm 02:27 PM

多くのユーザーはスマートウォッチを選ぶときにファーウェイブランドを選択しますが、その中でもファーウェイ GT3pro と GT4 は非常に人気のある選択肢であり、多くのユーザーはファーウェイ GT3pro と GT4 の違いに興味を持っています。 Huawei GT3pro と GT4 の違いは何ですか? 1. 外観 GT4: 46mm と 41mm、材質はガラスミラー + ステンレススチールボディ + 高解像度ファイバーバックシェルです。 GT3pro: 46.6mm および 42.9mm、材質はサファイアガラス + チタンボディ/セラミックボディ + セラミックバックシェルです。 2. 健全な GT4: 最新の Huawei Truseen5.5+ アルゴリズムを使用すると、結果はより正確になります。 GT3pro: ECG 心電図と血管と安全性を追加

修正: Windows 11 で Snipping ツールが機能しない 修正: Windows 11 で Snipping ツールが機能しない Aug 24, 2023 am 09:48 AM

Windows 11 で Snipping Tool が機能しない理由 問題の根本原因を理解すると、適切な解決策を見つけるのに役立ちます。 Snipping Tool が正しく動作しない主な理由は次のとおりです。 フォーカス アシスタントがオンになっている: これにより、Snipping Tool が開かなくなります。破損したアプリケーション: 起動時にスニッピング ツールがクラッシュする場合は、破損している可能性があります。古いグラフィック ドライバー: 互換性のないドライバーは、スニッピング ツールに干渉する可能性があります。他のアプリケーションからの干渉: 実行中の他のアプリケーションが Snipping Tool と競合する可能性があります。証明書の有効期限が切れています: アップグレード プロセス中のエラーにより、この問題が発生する可能性があります。これらの簡単な解決策は、ほとんどのユーザーに適しており、特別な技術知識は必要ありません。 1. Windows および Microsoft Store アプリを更新する

iPhoneでApp Storeに接続できないエラーを修正する方法 iPhoneでApp Storeに接続できないエラーを修正する方法 Jul 29, 2023 am 08:22 AM

パート 1: 最初のトラブルシューティング手順 Apple のシステムステータスを確認する: 複雑な解決策を掘り下げる前に、基本から始めましょう。問題はデバイスにあるのではなく、Apple のサーバーがダウンしている可能性があります。 Apple のシステム ステータス ページにアクセスして、AppStore が適切に動作しているかどうかを確認してください。問題があれば、Apple が修正してくれるのを待つしかありません。インターネット接続を確認します。「AppStore に接続できません」問題は接続不良が原因である場合があるため、安定したインターネット接続があることを確認してください。 Wi-Fi とモバイル データを切り替えるか、ネットワーク設定をリセットしてみてください ([一般] > [リセット] > [ネットワーク設定のリセット] > [設定])。 iOS バージョンを更新します。

Vue プロジェクトでデータ ページングと表示の最適化を実装する方法 Vue プロジェクトでデータ ページングと表示の最適化を実装する方法 Oct 15, 2023 am 09:27 AM

Vue プロジェクトでデータ ページングと表示の最適化を実装します。Vue プロジェクトでは、ページに大量のデータを表示する必要がある場合、通常、ユーザー エクスペリエンスを向上させるためにデータ ページングと表示の最適化を実行する必要があります。この記事では、Vue を使用して次のことを行う方法を紹介します。データ ページングと表示の最適化を実装し、具体的なコード例を提供します。 1. データページング データページングとは、大量のデータを一定の規則に従って複数のページに分割してページ上に表示することをいいます。次の手順を使用して、Vue プロジェクトにデータ ページングを実装できます: データ ソースを定義します。

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Vue2 がこれを通じてさまざまなオプションのプロパティにアクセスできる理由について話しましょう Vue2 がこれを通じてさまざまなオプションのプロパティにアクセスできる理由について話しましょう Dec 08, 2022 pm 08:22 PM

この記事は、vue ソース コードを解釈するのに役立ち、これを使用して Vue2 のさまざまなオプションのプロパティにアクセスできる理由を紹介します。

この点を理解してフロントエンド担当者の7割をキャッチアップした記事 この点を理解してフロントエンド担当者の7割をキャッチアップした記事 Sep 06, 2022 pm 05:03 PM

同僚は、これによって指摘されたバグのために立ち往生しました。Vue2 のこの指摘の問題により、アロー関数が使用され、その結果、対応する props を取得できなくなりました。私がそれを彼に紹介したとき、彼はそれを知りませんでした。その後、私はわざとフロントエンド コミュニケーション グループに目を向けました。これまでのところ、フロントエンド プログラマーの少なくとも 70% はまだそれを理解していません。今日私はそれを共有しますyou this link. もしすべてが間違っている場合 まだ学習していない場合は、大きな口を与えてください。

watch4proとGTのどちらが優れていますか? watch4proとGTのどちらが優れていますか? Sep 26, 2023 pm 02:45 PM

Watch4proとgtはそれぞれ特徴や適用シーンが異なりますが、総合的な機能、高性能、スタイリッシュな外観を重視し、価格は高くてもいいという方にはWatch 4 Proの方が適しているかもしれません。高度な機能要件はなく、バッテリー寿命と手頃な価格を重視する場合は、GT シリーズの方が適しているかもしれません。最終的な選択は、個人のニーズ、予算、好みに基づいて決定する必要がありますが、購入する前に自分のニーズを慎重に検討し、さまざまな製品のレビューや比較を参照して、より情報に基づいた選択を行うことをお勧めします。

See all articles