導航:首頁 > 編程語言 > php高性能分頁

php高性能分頁

發布時間:2024-12-06 15:02:24

php顯示很多資料庫信息,如何自動分頁呢代碼

PHP代碼如下:

/*

Author:默默
Date :2006-12-03

*/

$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那麼頁數就是1。
$num=10; //每頁顯示10條數據

$db=mysql_connect("host","name","pass"); //創建資料庫連接
$select=mysql_select_db("db",$db); //選擇要操作的資料庫

/*
首先咱們要獲取資料庫中到底有多少數據,才能判斷具體要分多少頁,具體的公式就是
總數據數除以每頁顯示的條數,有餘進一。
也就是說10/3=3.3333=4 有餘數就要進一。
*/

$total=mysql_num_rows(mysql_query("select id from table")); //查詢數據的總數,id是資料庫中的一個自動賦值的欄位
$pagenum=ceil($total/$num); //獲得總頁數

//假如傳入的頁數參數大於總頁數,則顯示錯誤信息
If($page>$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}

$offset=($page-1)*$num; //獲取limit的第一個參數的值,假如第一頁則為(1-1)*10=0,第二頁為(2-1)*10=10。

$info=mysql_query("select name from table limit $offset,$num"); //獲取相應頁數所需要顯示的數據,name是數據里的一個欄位
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數據

For($i=1;$i<=$pagenum;$i++){

$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}

/*顯示分頁信息,假如是當頁則顯示粗體的數字,其餘的頁數則為超連接,假如當前為第三頁則顯示如下
1 2 3 4 5 6
*/
?>

Ⅱ php應該怎樣分頁

我也和你一樣,看了好多例子都不懂,後來看了這個,總算搞懂了。這個還算簡單,是說的php mysql的分頁。

正文:
在看本文之前,請確保你已掌握了PHP的一些知識以及MYSQL的查詢操作基礎哦。

作為一個Web程序,經常要和不計其數的數據打交道,比如會員的數據,文章數據,假如只有幾十個會員那很好辦,在一頁顯示就可以了,可是假如你的網站是幾千甚至幾十萬會員的話,如果都在一頁打開的話無論對瀏覽器還是觀看者都是一種折磨。

相信每個學習PHP的新手都會對分頁這個東西感覺很頭疼,不過有了默默的這一水帖,你肯定會拍拍腦袋說,嘿,原來分頁竟然如此簡單?的確,現在請深呼吸一口新鮮的空氣,仔細的聽默默給你一點一點的分解。

假設我們要處理1000條數據,要在每頁中顯示10條,這樣的話就會分100頁來顯示,咱們先看一看在mysql里提取10條信息是如何操作的。

Select * from table limit 0,10

上面是一句很簡單的mysql查詢語句,它的作用是從一個名叫table的表裡提取10條數據,並且把所有欄位的值都獲得。

關鍵的地方就在這段「limit 0,10」,它其中的0是以0為起始點,後面的10則是顯示10條數據,那麼我們要以10為起始點,顯示到第20條數據該怎麼寫呢?

可能很多大大會心直口快的說「limit 10,20」嘛!啊哦,這樣可就錯誤了哦,正確的寫法是「limit 10,10」它後面的參數並非是結束點而是要提取的數目,記住哦。

懂得了如何提取10條數據,那麼提取1000條也就是做100次這種查詢呀,就是說要做如下的查詢:

Limit 0,10 //第一頁
Limit 10,10 //第二頁
Limit 20,10 //第三頁
Limit 30,10 //第四頁
……
看出有什麼規律了嗎?沒錯,第一個參數每翻一頁就增加10,可是第二個參數是不變的。
也就是說咱們設法根據頁數來改變第一個參數的值,就可以進行分頁顯示數據了,怎麼樣,原理是不是很簡單?

可是要怎麼設法根據頁數來改變第一個參數的值呢?首先,咱們要有一個頁數的值,用url的GET方式獲取。
比如index.php?page=18
相信大部分的大大對這個東西不陌生吧,這種url地址可是隨處可見,其中的page參數的作用就是傳入要顯示的頁數。

咱們通過一段代碼來看一看究竟是如何實現的吧:

PHP代碼如下:

/*

Author:默默
Date :2006-12-03

*/

$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那麼頁數就是1。
$num=10; //每頁顯示10條數據

$db=mysql_connect("host","name","pass"); //創建資料庫連接
$select=mysql_select_db("db",$db); //選擇要操作的資料庫

/*
首先咱們要獲取資料庫中到底有多少數據,才能判斷具體要分多少頁,具體的公式就是
總數據數除以每頁顯示的條數,有餘進一。
也就是說10/3=3.3333=4 有餘數就要進一。
*/

$total=mysql_num_rows(mysql_query("select id from table")); //查詢數據的總數,id是資料庫中的一個自動賦值的欄位
$pagenum=ceil($total/$num); //獲得總頁數

//假如傳入的頁數參數大於總頁數,則顯示錯誤信息
If($page>$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}

$offset=($page-1)*$num; //獲取limit的第一個參數的值,假如第一頁則為(1-1)*10=0,第二頁為(2-1)*10=10。

$info=mysql_query("select name from table limit $offset,$num"); //獲取相應頁數所需要顯示的數據,name是數據里的一個欄位
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數據

For($i=1;$i<=$pagenum;$i++){

$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}

/*顯示分頁信息,假如是當頁則顯示粗體的數字,其餘的頁數則為超連接,假如當前為第三頁則顯示如下
1 2 3 4 5 6
*/
?>

Ⅲ PHP+MySQL高效的分頁方法,如何優化LIMIT,OFFSET進行的分頁

很多應用往往只展示最新或最熱門的幾條記錄,但為了舊記錄仍然可訪問,所以就需要個分頁的導航欄。然而,如何通過MySQL更好的實現分頁,始終是比較令人頭疼的問題。雖然沒有拿來就能用的解決辦法,但了解資料庫的底層或多或少有助於優化分頁查詢。

我們先從一個常用但性能很差的查詢來看一看。

SELECT *
FROM city
ORDER BY id DESC
LIMIT 0, 15

這個查詢耗時0.00sec。So,這個查詢有什麼問題呢?實際上,這個查詢語句和參數都沒有問題,因為它用到了下面表的主鍵,而且只讀取15條記錄。

CREATE TABLE city (
id int(10) unsigned NOT NULL AUTO_INCREMENT,
city varchar(128) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB;

真正的問題在於offset(分頁偏移量)很大的時候,像下面這樣:

SELECT *
FROM city
ORDER BY id DESC
LIMIT 100000, 15;

上面的查詢在有2M行記錄時需要0.22sec,通過EXPLAIN查看SQL的執行計劃可以發現該SQL檢索了100015行,但最後只需要15行。大的分頁偏移量會增加使用的數據,MySQL會將大量最終不會使用的數據載入到內存中。就算我們假設大部分網站的用戶只訪問前幾頁數據,但少量的大的分頁偏移量的請求也會對整個系統造成危害。Facebook意識到了這一點,但Facebook並沒有為了每秒可以處理更多的請求而去優化資料庫,而是將重心放在將請求響應時間的方差變小。

對於分頁請求,還有一個信息也很重要,就是總共的記錄數。我們可以通過下面的查詢很容易的獲取總的記錄數。

SELECT COUNT(*)
FROM city;

然而,上面的SQL在採用InnoDB為存儲引擎時需要耗費9.28sec。一個不正確的優化是採用 SQL_CALC_FOUND_ROWS,SQL_CALC_FOUND_ROWS 可以在能夠在分頁查詢時事先准備好符合條件的記錄數,隨後只要執行一句 select FOUND_ROWS(); 就能獲得總記錄數。但是在大多數情況下,查詢語句簡短並不意味著性能的提高。不幸的是,這種分頁查詢方式在許多主流框架中都有用到,下面看看這個語句的查詢性能。

SELECT SQL_CALC_FOUND_ROWS *
FROM city
ORDER BY id DESC
LIMIT 100000, 15;

這個語句耗時20.02sec,是上一個的兩倍。事實證明使用 SQL_CALC_FOUND_ROWS 做分頁是很糟糕的想法。
下面來看看到底如何優化。文章分為兩部分,第一部分是如何獲取記錄的總數目,第二部分是獲取真正的記錄。

高效的計算行數

如果採用的引擎是MyISAM,可以直接執行COUNT(*)去獲取行數即可。相似的,在堆表中也會將行數存儲到表的元信息中。但如果引擎是InnoDB情況就會復雜一些,因為InnoDB不保存表的具體行數。

我們可以將行數緩存起來,然後可以通過一個守護進程定期更新或者用戶的某些操作導致緩存失效時,執行下面的語句:

SELECT COUNT(*)
FROM city
USE INDEX(PRIMARY);

獲取記錄

下面進入這篇文章最重要的部分,獲取分頁要展示的記錄。上面已經說過了,大的偏移量會影響性能,所以我們要重寫查詢語句。為了演示,我們創建一個新的表「news」,按照時事性排序(最新發布的在最前面),實現一個高性能的分頁。為了簡單,我們就假設最新發布的新聞的Id也是最大的。

CREATE TABLE news(
id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
title VARCHAR(128) NOT NULL
) ENGINE=InnoDB;

一個比較高效的方式是基於用戶展示的最後一個新聞Id。查詢下一頁的語句如下,需要傳入當前頁面展示的最後一個Id。

SELECT *
FROM news WHERE id < $last_id
ORDER BY id DESC
LIMIT $perpage

查詢上一頁的語句類似,只不過需要傳入當前頁的第一個Id,並且要逆序。

SELECT *
FROM news WHERE id > $last_id
ORDER BY id ASC
LIMIT $perpage

上面的查詢方式適合實現簡易的分頁,即不顯示具體的頁數導航,只顯示「上一頁」和「下一頁」,例如博客中頁腳顯示「上一頁」,「下一頁」的按鈕。但如果要實現真正的頁面導航還是很難的,下面看看另一種方式。

SELECT id
FROM (
SELECT id, ((@cnt:= @cnt + 1) + $perpage - 1) % $perpage cnt
FROM news
JOIN (SELECT @cnt:= 0)T
WHERE id < $last_id
ORDER BY id DESC
LIMIT $perpage * $buttons
)C
WHERE cnt = 0;

通過上面的語句可以為每一個分頁的按鈕計算出一個offset對應的id。這種方法還有一個好處。假設,網站上正在發布一片新的文章,那麼所有文章的位置都會往後移一位,所以如果用戶在發布文章時換頁,那麼他會看見一篇文章兩次。如果固定了每個按鈕的offset Id,這個問題就迎刃而解了。Mark Callaghan發表過一篇類似的博客,利用了組合索引和兩個位置變數,但是基本思想是一致的。

如果表中的記錄很少被刪除、修改,還可以將記錄對應的頁碼存儲到表中,並在該列上創建合適的索引。採用這種方式,當新增一個記錄的時候,需要執行下面的查詢重新生成對應的頁號。

SET p:= 0;
UPDATE news SET page=CEIL((p:= p + 1) / $perpage) ORDER BY id DESC;

當然,也可以新增一個專用於分頁的表,可以用個後台程序來維護。

UPDATE pagination T
JOIN (
SELECT id, CEIL((p:= p + 1) / $perpage) page
FROM news
ORDER BY id
)C
ON C.id = T.id
SET T.page = C.page;

現在想獲取任意一頁的元素就很簡單了:

SELECT *
FROM news A
JOIN pagination B ON A.id=B.ID
WHERE page=$offset;

還有另外一種與上種方法比較相似的方法來做分頁,這種方式比較試用於數據集相對小,並且沒有可用的索引的情況下—比如處理搜索結果時。在一個普通的伺服器上執行下面的查詢,當有2M條記錄時,要耗費2sec左右。這種方式比較簡單,創建一個用來存儲所有Id的臨時表即可(這也是最耗費性能的地方)。

CREATE TEMPORARY TABLE _tmp (KEY SORT(random))
SELECT id, FLOOR(RAND() * 0x8000000) random
FROM city;

ALTER TABLE _tmp ADD OFFSET INT UNSIGNED PRIMARY KEY AUTO_INCREMENT, DROP INDEX SORT,ORDER BY random;

接下來就可以向下面一樣執行分頁查詢了。

SELECT *
FROM _tmp
WHERE OFFSET >= $offset
ORDER BY OFFSET
LIMIT $perpage;

簡單來說,對於分頁的優化就是。。。避免數據量大時掃描過多的記錄。

Ⅳ PHP鍒嗛〉鏄劇ず鍒朵綔璇﹁В

銆銆 鍓嶈█

銆銆鍒嗛〉鏄劇ず鏄涓縐嶉潪甯稿父瑙佺殑嫻忚堝拰鏄劇ず澶ч噺鏁版嵁鐨勬柟娉 灞炰簬web緙栫▼涓鏈甯稿勭悊鐨勪簨浠朵箣涓 瀵逛簬web緙栫▼鐨勮佹墜鏉ヨ 緙栧啓榪欑嶄唬鐮佸疄鍦ㄦ槸鍜屽懠鍚鎬竴鏍瘋嚜鐒 浣嗘槸瀵逛簬鍒濆﹁呮潵璇 甯稿父瀵硅繖涓闂棰樻懜涓嶈憲澶寸華 鍥犳ょ壒鍦版挵鍐欐ゆ枃瀵硅繖涓闂棰樿繘琛岃︾粏鐨勮茶В 鍔涙眰璁╃湅瀹岃繖綃囨枃絝犵殑鏈嬪弸鍦ㄧ湅瀹屼互鍚庡逛簬鍒嗛〉鏄劇ず鐨勫師鐞嗗拰瀹炵幇鏂規硶鏈夋墍浜嗚В 鏈鏂囬傚悎鍒濆﹁呴槄璇 鎵鏈夌ず渚嬩唬鐮佸潎浣跨敤php緙栧啓

銆銆 鍘熺悊

銆銆鎵璋撳垎欏墊樉紺 涔熷氨鏄灝嗘暟鎹搴撲腑鐨勭粨鏋滈泦浜轟負鐨勫垎鎴愪竴孌典竴孌電殑鏉ユ樉紺 榪欓噷闇瑕佷袱涓鍒濆嬬殑鍙傛暟

銆銆姣忛〉澶氬皯鏉¤板綍($PageSize)?

銆銆褰撳墠鏄絎鍑犻〉($CurrentPageID)?

銆銆鐜板湪鍙瑕佸啀緇欐垜涓涓緇撴灉闆 鎴戝氨鍙浠ユ樉紺烘煇孌電壒瀹氱殑緇撴灉鍑烘潵

銆銆鑷充簬鍏朵粬鐨勫弬鏁 姣斿 涓婁竴欏($PReviousPageID) 涓嬩竴欏($NextPageID) 鎬婚〉鏁($numPages)絳夌瓑 閮藉彲浠ユ牴鎹鍓嶈竟榪欏嚑涓涓滆タ寰楀埌

銆銆浠MySQL鏁版嵁搴撲負渚 濡傛灉瑕佷粠琛ㄥ唴鎴鍙栨煇孌靛唴瀹 sql璇鍙ュ彲浠ョ敤 select * from table limit offset rows 鐪嬬湅涓嬮潰涓緇剆ql璇鍙 灝濊瘯涓涓嬪彂鐜板叾涓鐨勮勭巼

銆銆鍓 鏉¤板綍 select * from table limit

銆銆絎 鑷 鏉¤板綍 select * from table limit

銆銆絎 鑷 鏉¤板綍 select * from table limit

銆銆鈥︹

銆銆榪欎竴緇剆ql璇鍙ュ叾瀹炲氨鏄褰$PageSize= 鐨勬椂鍊欏彇琛ㄥ唴姣忎竴欏墊暟鎹鐨剆ql璇鍙 鎴戜滑鍙浠ユ葷粨鍑鴻繖鏍蜂竴涓妯℃澘

銆銆select * from table limit ($CurrentPageID ) * $PageSize $PageSize

銆銆鎷胯繖涓妯℃澘浠e叆瀵瑰簲鐨勫煎拰涓婅竟閭d竴緇剆ql璇鍙ュ圭収涓涓嬬湅鐪嬫槸涓嶆槸閭d箞鍥炰簨 鎼炲畾浜嗘渶閲嶈佺殑濡備綍鑾峰彇鏁版嵁鐨勯棶棰樹互鍚 鍓╀笅鐨勫氨浠呬粎鏄浼犻掑弬鏁 鏋勯犲悎閫傜殑sql璇鍙ョ劧鍚庝嬌鐢╬hp浠庢暟鎹搴撳唴鑾峰彇鏁版嵁騫舵樉紺轟簡 浠ヤ笅鎴戝皢鐢ㄥ叿浣撲唬鐮佸姞浠ヨ存槑

銆銆 綆鍗曚唬鐮

銆銆璇瘋︾粏闃呰諱互涓嬩唬鐮 鑷宸辮皟璇曡繍琛屼竴嬈 鏈濂芥妸瀹冧慨鏀逛竴嬈 鍔犱笂鑷宸辯殑鍔熻兘 姣斿傛悳緔㈢瓑絳

銆銆 <?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 = ''

銆銆if( $page == 1 ){

銆銆$page_string .= '絎涓欏祙涓婁竴欏祙'

銆銆}

銆銆else{

銆銆$page_string .= '<a href=?page=1>絎涓欏</a>|<a .($page-1).'>涓婁竴欏</a>|' }

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

銆銆$page_string .= '涓嬩竴欏祙灝鵑〉'

銆銆}

銆銆else{

銆銆$page_string .= '<a .($page+1).'>涓嬩竴欏</a>|<a .$page_count.'>灝鵑〉</a>' }

銆銆// 鑾峰彇鏁版嵁錛屼互浜岀淮鏁扮粍鏍煎紡榪斿洖緇撴灉

銆銆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();

銆銆}

銆銆// 娌℃湁鍖呭惈鏄劇ず緇撴灉鐨勪唬鐮侊紝閭d笉鍦ㄨㄨ鴻寖鍥達紝鍙瑕佺敤foreach灝卞彲浠ュ緢綆鍗曠殑鐢ㄥ緱鍒扮殑浜岀淮鏁扮粍鏉ユ樉紺虹粨鏋

銆銆?>

銆銆4銆丱O椋庢牸浠g爜

銆銆浠ヤ笅浠g爜涓鐨勬暟鎹搴撹繛鎺ユ槸浣跨敤鐨刾ear db綾昏繘琛屽勭悊

銆銆 <?php

銆銆// FileName: Pager.class.php

銆銆// 鍒嗛〉綾伙紝榪欎釜綾諱粎浠呯敤浜庡勭悊鏁版嵁緇撴瀯錛屼笉璐熻矗澶勭悊鏄劇ず鐨勫伐浣

銆銆Class Pager

銆銆{

銆銆var $PageSize; //姣忛〉鐨勬暟閲

銆銆var $CurrentPageID; //褰撳墠鐨勯〉鏁

銆銆var $NextPageID; //涓嬩竴欏

銆銆var $PreviousPageID; //涓婁竴欏

銆銆var $numPages; //鎬婚〉鏁

銆銆var $numItems; //鎬昏板綍鏁

銆銆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;

銆銆default:

銆銆$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;

銆銆}

銆銆/***

銆銆*

銆銆* 榪斿洖緇撴灉闆嗙殑鏁版嵁搴撹繛鎺

銆銆* 鍦ㄧ粨鏋滈泦姣旇緝澶х殑鏃跺欏彲浠ョ洿鎺ヤ嬌鐢ㄨ繖涓鏂規硶鑾峰緱鏁版嵁搴撹繛鎺ワ紝鐒跺悗鍦ㄧ被涔嬪栭亶鍘嗭紝榪欐牱寮閿杈冨皬

銆銆* 濡傛灉緇撴灉闆嗕笉鏄寰堝ぇ錛屽彲浠ョ洿鎺ヤ嬌鐢╣etPageData鐨勬柟寮忚幏鍙栦簩緇存暟緇勬牸寮忕殑緇撴灉

銆銆* 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;

銆銆}

銆銆}

銆銆/***

銆銆*

銆銆* 浠ヤ簩緇存暟緇勭殑鏍煎紡榪斿洖緇撴灉闆

銆銆*

銆銆***/

銆銆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;

銆銆}

銆銆}

銆銆function _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

銆銆// FileName: test_pager.php

銆銆// 榪欐槸涓孌電畝鍗曠殑紺轟緥浠g爜錛屽墠杈圭渷鐣ヤ簡浣跨敤pear db綾誨緩絝嬫暟鎹搴撹繛鎺ョ殑浠g爜

銆銆require "Pager.class.php";

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

銆銆{

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

銆銆}

銆銆else

銆銆{

銆銆$page = 1;

銆銆}

銆銆$sql = "select * from table order by id";

銆銆$pager_option = array(

銆銆"sql" => $sql,

銆銆"PageSize" => 10,

銆銆"CurrentPageID" => $page

銆銆);

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

銆銆{

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

銆銆}

銆銆$pager = @new Pager($pager_option);

銆銆$data = $pager->getPageData();

銆銆if ( $pager->isFirstPage )

銆銆{

銆銆$turnover = "棣栭〉|涓婁竴欏祙";

銆銆}

銆銆else

銆銆{

銆銆$turnover = "<a ?page=1&numItems=".$pager->numItems."'>棣栭〉</a>|<a ?page=".$pager->PreviousPageID."&numItems=".$pager->numItems."'>涓婁竴欏</a>|"; }

銆銆if ( $pager->isLastPage )

銆銆{

銆銆$turnover .= "涓嬩竴欏祙灝鵑〉";

銆銆}

銆銆else

銆銆{

銆銆$turnover .="<a ?page=".$pager->NextPageID."&numItems=".$pager->numItems."'>涓嬩竴欏</a>|<a ?page=".$pager->numPages."&numItems=".$pager->numItems."'>灝鵑〉</a>"; }

銆銆?>

銆銆闇瑕佽存槑鐨勫湴鏂規湁涓や釜錛

銆銆榪欎釜綾諱粎浠呭勭悊鏁版嵁錛屽苟涓嶈礋璐e勭悊鏄劇ず錛屽洜涓烘垜瑙夊緱灝嗘暟鎹鐨勫勭悊鍜岀粨鏋滅殑鏄劇ず閮芥斁鍒頒竴涓綾婚噷杈瑰疄鍦ㄦ槸鏈変簺鍕夊己銆俆w.wINgWIT鏄劇ず鐨勬椂鍊欐儏鍐靛拰瑕佹眰澶氬彉錛屼笉濡傝嚜宸辨牴鎹綾葷粰鍑虹殑緇撴灉澶勭悊錛屾洿濂界殑鏂規硶鏄鏍規嵁榪欎釜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 = "select * from members order by id";

銆銆$pager_option = array(

銆銆"sql" => $sql,

銆銆"PageSize" => 10,

銆銆"CurrentPageID" => $page

銆銆);

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

銆銆{

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

銆銆}

銆銆$pager = @new MemberPager($pager_option);

銆銆$pager->showMemberList();

銆銆?>

銆銆絎浜屼釜闇瑕佽存槑鐨勫湴鏂瑰氨鏄涓嶅悓鏁版嵁搴撶殑鍏煎規э紝鍦ㄤ笉鍚岀殑鏁版嵁搴撻噷鎴鑾蜂竴孌電粨鏋滅殑鍐欐硶鏄涓嶄竴鏍風殑銆

銆銆mysql: select * from table limit offset, rows

銆銆pgsql: select * from table limit m offset n

銆銆......

lishixin/Article/program/PHP/201311/21304

Ⅳ 我是做php的,想實現一個分頁效果,就是循環出現頁碼,第11頁的時候。顯示從11到20頁

1.###page.php###
//獲取page的值,假如不存在page,設置頁數為1。
$page=isset($_GET['page'])?intval($_GET['page']):1;
$num=10; //設置每頁顯示幾個數據
$total=mysql_num_rows(mysql_query("select * from XXX"));//計算所有數據總數
$pagenum=ceil($total/$num); //總數除以每頁顯示數,計算出頁數
//假如傳入的頁數參數大於總頁數,則顯示錯誤信息
if($page>$pagenum || $page == 0){
echo "error";
Exit;
}
$offset=($page-1)*$num; //獲取limit的第一個參數

2.###index.php####
require("page.php");//引入page.php文件
//循環顯示資料庫內容,倒序排列,定義每頁顯示多少條信息
$result = mysql_query(SELECT * FROM num order by id desc limit $offset,$num);
... ...
//循環顯示分頁頁碼開始
for($i=1;$i<=$pagenum;$i++){

$show=($i!=$page)?"<a href='tel.php?page=".$i."'>$i</a>":"<b>$i</b>";
Echo $show." ";
}

Ⅵ phpcms V9 解決內容頁太長怎麼手動分頁

在phpcms的內容編輯器中使用分頁符可實現手動分頁,如下圖:

使用方法:

將游標移動到要分頁的位置,然後點擊,會自動插入分頁符[page]。另外,確保「分頁方式」一項選擇「手動分頁」。這樣,當內容在前端顯示的時候會自動在此處斷開分頁了。

注意:

  1. 手動分頁的時候插入位置要合理,主要是避免將內容中成對的html標簽拆開而造成顯示不正常。

  2. phpcms後台使用教程可參考官方文檔和iphpcms的教程。

Ⅶ php中的分頁顯示

1、前言

分頁顯示是一種非常常見的瀏覽和顯示大量數據的方法,屬於web編程中最常處理的事件之一。對於web編程的老手來說,編寫這種代碼實在是和呼吸一樣自然,但是對於初學者來說,常常對這個問題摸不著頭緒,因此特地撰寫此文對這個問題進行詳細的講解,力求讓看完這篇文章的朋友在看完以後對於分頁顯示的原理和實現方法有所了解。本文適合初學者閱讀,所有示例代碼均使用php編寫。

2、原理

所謂分頁顯示,也就是將資料庫中的結果集人為的分成一段一段的來顯示,這里需要兩個初始的參數:

每頁多少條記錄($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

拿這個模板代入對應的值和上邊那一組sql語句對照一下看看是不是那麼回事。搞定了最重要的如何獲取數據的問題以後,剩下的就僅僅是傳遞參數,構造合適的sql語句然後使用php從資料庫內獲取數據並顯示了。以下我將用具體代碼加以說明。

3、簡單代碼
請詳細閱讀以下代碼,自己調試運行一次,最好把它修改一次,加上自己的功能,比如搜索等等。

<?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 = '';
if( $page == 1 ){
$page_string .= '第一頁|上一頁|';
}
else{
$page_string .= '<a href="/?page=1>";第一頁</a>|<a href="/?page='."($page-1).'>上一頁</a>|';
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= '下一頁|尾頁';
}
else{
$page_string .= '<a href="/?page='."($page+1).'>下一頁</a>|<a href="/?page='."$page_count.'>尾頁</a>';
}
// 獲取數據,以二維數組格式返回結果
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類進行處理

<?php
// FileName: Pager.class.php
// 分頁類,這個類僅僅用於處理數據結構,不負責處理顯示的工作
Class Pager
{
var $PageSize; //每頁的數量
var $CurrentPageID; //當前的頁數
var $NextPageID; //下一頁
var $PreviousPageID; //上一頁
var $numPages; //總頁數
var $numItems; //總記錄數
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;
default:
$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的方式獲取二維數組格式的結果
* 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;
}
}

/***
*
* 以二維數組的格式返回結果集
*
***/

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

function _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
// FileName: 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";
$pager_option = array(
"sql" => $sql,
"PageSize" => 10,
"CurrentPageID" => $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option);
$data = $pager->getPageData();
if ( $pager->isFirstPage )
{
$turnover = "首頁|上一頁|";
}
else
{
$turnover = "<a href='?page=1&numItems=".$pager->numItems."'>首頁</a>|<a href="/?page=".$pager->PreviousPageID."&numItems=".$pager->numItems."'>上一頁</a>|";
}
if ( $pager->isLastPage )
{
$turnover .= "下一頁|尾頁";
}
else
{
$turnover .= "<a href="/?page=".$pager->NextPageID."&numItems=".$pager->numItems."'>下一頁</a>|<a href="/?page=".$pager->numPages."&numItems=".$pager->numItems."'>尾頁</a>";
}
?>

需要說明的地方有兩個:

這個類僅僅處理數據,並不負責處理顯示,因為我覺得將數據的處理和結果的顯示都放到一個類里邊實在是有些勉強。顯示的時候情況和要求多變,不如自己根據類給出的結果處理,更好的方法是根據這個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 = "select * from members order by id";
$pager_option = array(
"sql" => $sql,
"PageSize" => 10,
"CurrentPageID" => $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new MemberPager($pager_option);
$pager->showMemberList();
?>

第二個需要說明的地方就是不同資料庫的兼容性,在不同的資料庫里截獲一段結果的寫法是不一樣的。
mysql: select * from table limit offset, rows
pgsql: select * from table limit m offset n
......
所以要在類里邊獲取結果的時候需要使用pear db類的limitQuery方法。

ok,寫完收功,希望花時間看完這些文字的你不覺得是浪費了時間。

閱讀全文

與php高性能分頁相關的資料

熱點內容
精品php源碼 瀏覽:960
自己編寫雲伺服器搶紅包 瀏覽:203
java解壓縮文件加密 瀏覽:887
dlink列印伺服器默認地址 瀏覽:353
php休眠函數 瀏覽:372
金蝶如何打開伺服器 瀏覽:766
e4a手游輔助源碼 瀏覽:777
什麼app可以實時直播 瀏覽:106
蘋果13的app閃退什麼原因 瀏覽:775
尾盤選股源碼公式 瀏覽:450
php日期運算 瀏覽:931
天龍八部長歌伺服器什麼時候開的 瀏覽:199
鬼泣4模型在那個文件夾 瀏覽:229
單片機的串列口 瀏覽:58
phpjson轉化為數組 瀏覽:268
pdf導入excel 瀏覽:428
蘋果xsmax信任app在哪裡設置 瀏覽:53
自動外鏈php源碼 瀏覽:245
我的世界新手獎勵箱命令 瀏覽:146
linux更新vim 瀏覽:998