>  기사  >  백엔드 개발  >  PHP 페이지 매김 display_PHP 튜토리얼에 대한 자세한 설명

PHP 페이지 매김 display_PHP 튜토리얼에 대한 자세한 설명

WBOY
WBOY원래의
2016-07-22 09:02:452080검색

1. 서문

페이징 표시는 대량의 데이터를 탐색하고 표시하는 매우 일반적인 방법이며 웹 프로그래밍에서 가장 일반적으로 처리되는 이벤트 중 하나입니다. 웹 프로그래밍 베테랑들에게는 이런 코드를 작성하는 것이 숨 쉬는 것처럼 자연스러운 일이지만, 초보자들에게는 이 문제에 대해 혼동하는 경우가 많기 때문에 이 문제를 자세히 설명하기 위해 특별히 이 글을 썼습니다. 이 기사를 마치면 페이징 표시의 원리와 구현 방법을 어느 정도 이해하게 될 것입니다. 이 글은 초보자가 읽기에 적합하며, 모든 샘플 코드는 PHP로 작성되었습니다.

2. 원칙

소위 페이징 표시는 데이터베이스의 결과 세트가 표시를 위해 인위적으로 섹션으로 나누어지는 것을 의미합니다. 여기에는 두 개의 초기 매개변수가 필요합니다.

페이지당 레코드 수($PageSize)는 무엇입니까?

현재 페이지($CurrentPageID)는 어떤 페이지인가요?

이제 다른 결과 세트를 제공하기만 하면 특정 결과를 표시할 수 있습니다.

이전 페이지($PReviousPageID), 다음 페이지($NextPageID), 총 페이지 수($numPages) 등과 같은 기타 매개변수는 이전 항목을 기반으로 얻을 수 있습니다.

MySQL 데이터베이스를 예로 들면, 테이블의 특정 콘텐츠를 가로채려는 경우 sql 문을 사용할 수 있습니다. select * from tablelimit offset,rows. 다음 SQL 문 세트를 살펴보고 규칙을 찾아보세요.

처음 10개 레코드: 테이블 제한 0,10에서 * 선택

레코드 11~20: 테이블 제한 10,10에서 * 선택

레코드 21~30: 테이블 제한 20,10에서 * 선택

 …

이 SQL 문 세트는 실제로 $PageSize=10일 때 테이블의 각 페이지에서 데이터를 가져오기 위한 SQL 문입니다.

테이블 제한에서 * 선택($CurrentPageID - 1) * $PageSize, $PageSize

이 템플릿을 가져와 해당 값을 삽입하고 위의 SQL 문 세트와 비교하여 이것이 사실인지 확인하세요. 데이터를 얻는 방법에 대한 가장 중요한 문제를 해결한 후에 남은 것은 매개변수를 전달하고 적절한 SQL 문을 구성한 다음 PHP를 사용하여 데이터베이스에서 데이터를 가져와 표시하는 것입니다. 아래에서는 구체적인 코드로 설명하겠습니다.

3. 간단한 코드

다음 코드를 자세히 읽어보시고 직접 디버그해 보시고 실행해 보시는 것이 가장 좋을 것 같습니다.

 

// 데이터베이스 연결 설정

$link = mysql_connect("localhost", "mysql_user", "mysql_passWord")

또는 die("연결할 수 없습니다: " . mysql_error());

// 현재 페이지 번호를 가져옵니다

 if( isset($_GET['page']) ){

 $page = intval( $_GET['page'] );

 }

그 외{

 $페이지 = 1;

 }

// 페이지당 수량

 $PageSize = 10;

// 전체 데이터 볼륨을 가져옵니다

 $sql = "테이블에서 금액으로 count(*) 선택";

 $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을 더한 값입니다.

 }그 외{

 $page_count = $amount / $page_size; //나머지가 없으면 페이지 수는 전체 데이터 양을 페이지 수로 나눈 값입니다

 }

 }

그 외{

 $page_count = 0;

 }

// 페이지 넘김 링크

$page_string = '';

 if( $page == 1 ){

 $page_string .= '첫 번째 페이지|이전 페이지|';

 }

그 외{

 $page_string .= '첫 번째 페이지|이전 페이지 |';
}

 if( ($page == $page_count) || ($page_count == 0) ){

$page_string .= '다음 페이지|마지막 페이지';

 }

그 외{

 $page_string .= '다음 페이지|';
}

// 데이터를 가져와서 2차원 배열 형식으로 결과를 반환합니다

 if( $amount ){

 $sql = "ID 설명 제한에 따라 테이블 순서에서 *를 선택합니다. ".($page-1)*$page_size .", $page_size";

 $result = mysql_query($sql);

동안( $row = mysql_fetch_row($result) ){

$rowset[] = $row;

 }

 }그 외{

 $rowset = array();

 }

// 결과를 표시하는 코드가 없으므로 이는 논의 범위를 벗어납니다. 간단히 얻은 2차원 배열을 사용하여 foreach를 사용하여 결과를 표시할 수 있습니다.

 ?>

4. OO 스타일 코드

다음 코드의 데이터베이스 연결은 pear db 클래스를 사용하여 처리됩니다.

 

// 파일명: Pager.class.php

// 페이징 클래스, 이 클래스는 데이터 구조를 처리하는 데만 사용되며 디스플레이 처리는 담당하지 않습니다.

 학급 호출기

 {

 var $PageSize; //각 페이지 수

 var $CurrentPageID //현재 페이지 번호

 var $NextPageID //다음 페이지

 var $PreviousPageID //이전 페이지

 var $numPages; //총 페이지 수

 var $numItems; //총 레코드 수

 var $isFirstPage; //첫 번째 페이지인지 여부

 var $isLastPage; //마지막 페이지인지 여부

 var $sql; //sql 쿼리문

함수 호출기($option)

 {

글로벌 $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;

 }

그밖에

 {

$this->numPages = $this->numItems / $this->PageSize;

 }

 }

그밖에

 {

$this->numPages = 0;

 }

스위치( $this->CurrentPageID )

 {

사례 $this->numPages == 1:

$this->isFirstPage = true;

$this->isLastPage = true;

휴식;

사례 1:

$this->isFirstPage = true;

$this->isLastPage = false;

휴식;

케이스 $this->numPages:

$this->isFirstPage = false;

$this->isLastPage = true;

휴식;

기본값:

$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 - }

 }

true를 반환합니다.

 }

 /***

*

 * 결과 집합의 데이터베이스 연결을 반환합니다

* 결과 집합이 상대적으로 큰 경우 이 방법을 직접 사용하여 데이터베이스 연결을 얻은 다음 클래스 외부로 순회할 수 있어 오버헤드가 적습니다.

* 결과 집합이 그다지 크지 않은 경우 getPageData를 직접 사용하여 2차원 배열 형식으로 결과를 얻을 수 있습니다.

* getPageData 메소드도 이 메소드를 호출하여 결과를 얻습니다

*

***/

getDataLink() 함수

 {

 if ( $this->numItems )

 {

글로벌 $db;

$PageID = $this->CurrentPageID;

 $from = ($PageID - 1)*$this->PageSize;

$count = $this->PageSize;

 $link = $db->limitQuery($this->sql, $from, $count); //데이터베이스 호환성을 보장하려면 Pear DB::limitQuery 메소드를 사용하세요

$link 반환;

 }

그밖에

 {

false를 반환합니다.

 }

 }

 /***

*

* 결과 집합을 2차원 배열 형식으로 반환

*

***/

getPageData() 함수

 {

 if ( $this->numItems )

 {

 if ( $res = $this->getDataLink() )

 {

 if ( $res->numRows() )

 {

while( $row = $res->fetchRow() )

 {

 $result[] = $row;

 }

 }

그밖에

 {

 $result = 배열();

 }

$결과 반환;

 }

그밖에

 {

false를 반환합니다.

 }

 }

그밖에

 {

false를 반환합니다.

 }

 }

함수 _setOptions($option)

 {

 $allow_options = 배열(

 '페이지 크기',

'현재페이지ID',

 'sql',

 '항목 수'

 );

 foreach( $key => $value 로 $option )

 {

 if ( in_array($key, $allow_options) && ($value != null) )

 {

$this->$key = $value;

 }

 }

true를 반환합니다.

 }

 }

 ?>

 

// 파일명: test_pager.php

//간단한 샘플 코드이며, pear db 클래스를 사용하여 데이터베이스 연결을 설정하는 코드는 생략했습니다

"Pager.class.php"가 필요합니다.

 if ( isset($_GET['page']) )

 {

 $page = (int)$_GET['page'];

 }

그밖에

 {

 $페이지 = 1;

 }

 $sql = "ID별로 테이블 순서에서 * 선택";

 $pager_option = 배열(

 "sql" => $sql,

 "PageSize" => 10,

 "현재페이지ID" =>$페이지

 );

 if ( isset($_GET['numItems']) )

 {

 $pager_option['numItems'] = (int)$_GET['numItems'];

 }

$pager = @new Pager($pager_option);

$data = $pager->getPageData();

 if ( $pager->isFirstPage )

 {

 $turnover = "홈페이지|이전 페이지|";

 }

그밖에

 {

 $turnover = "홈페이지|이전 페이지|";
}

 if ( $pager->isLastPage )

 {

 $turnover .= "다음 페이지|마지막 페이지";

 }

그밖에

 {

 $turnover .="다음 페이지 |< ;a href='?page=".$pager->numPages."&numItems=".$pager->numItems."'>마지막 페이지";
}

 ?>

설명해야 할 두 가지가 있습니다.

이 클래스는 데이터 처리만 하고 표시는 담당하지 않습니다. 데이터 처리와 결과 표시를 하나의 클래스에 넣는 것이 좀 꺼려지는 것 같아서요. 표시할 때 상황과 요구 사항은 변경 가능합니다. 클래스에서 제공하는 결과에 따라 처리하는 것이 좋습니다. 더 좋은 방법은 Pager 클래스를 기반으로 자체 하위 클래스를 상속하여 다른 페이지 매김을 표시하는 것입니다. 사용자 페이지 매기기 목록은 다음과 같습니다.

 

Class MemberPager는 Pager를 확장합니다

 {

함수 showMemberList()

 {

글로벌 $db;

$data = $this->getPageData();

// 결과를 표시하는 코드

 //......

 }

 }

 /// 전화

 if ( isset($_GET['page']) )

 {

 $page = (int)$_GET['page'];

 }

그밖에

 {

 $페이지 = 1;

 }

 $sql = "ID별 회원순으로 *선택";

 $pager_option = 배열(

 "sql" => $sql,

 "PageSize" => 10,

 "현재페이지ID" =>$페이지

 );

 if ( isset($_GET['numItems']) )

 {

 $pager_option['numItems'] = (int)$_GET['numItems'];

 }

 $pager = @new MemberPager($pager_option);

$pager->showMemberList();

 ?>

두 번째로 설명해야 할 것은 서로 다른 데이터베이스의 호환성입니다. 서로 다른 데이터베이스에서는 결과를 작성하는 방법이 다릅니다.

mysql: 테이블 제한 오프셋, 행에서 * 선택

pgsql: 테이블 제한 m 오프셋 n에서 * 선택

 …

따라서 클래스에서 결과를 얻으려면 pear db 클래스의limitQuery 메소드를 사용해야 합니다.

www.bkjia.comhttp: //www.bkjia.com/PHPjc/371844.htmlTechArticle1. 서문 페이지 매김 표시는 대량의 데이터를 탐색하고 표시하는 가장 일반적인 방법입니다. 웹 프로그래밍에서 일반적으로 처리되는 이벤트 중 하나입니다. 웹 프로그래밍 베테랑이라면 이 코드를 작성해보세요...
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.