1、首先了解SQL語句中的limit用法php
SELECT * FROM table …… limit 開始位置 , 操做條數 (其中開始位置是從0開始的)html
例子:mysql
取前20條記錄:SELECT * FROM table …… limit 0 , 20
從第11條開始取20條記錄:SELECT * FROM table …… limit 10 , 20sql
LIMIT n 等價於 LIMIT 0,n。數據庫
如select * from table LIMIT 5; //返回前5行,和 select * from table LIMIT 0,5同樣數組
2、分頁原理服務器
所謂分頁顯示,也就是講數據庫中的結果集,一段一段顯示出來數據庫設計
怎麼分段,當前在第幾段 (每頁有幾條,當前再第幾頁)函數
前10條記錄:select * from table limit 0,10
第11至20條記錄:select * from table limit 10,10
第21至30條記錄:select * from table limit 20,10fetch
分頁公式:
(當前頁數 - 1 )X 每頁條數,每頁條數
Select * from table limit ($Page- 1) * $PageSize, $PageSize
3、$_SERVER["REQUEST_URI"]函數
預約義服務器變量的一種,全部$_SERVER開頭的都叫作預約於服務器變量。
REQUEST_URI的做用是取得當前URI,也就除域名外後面的完整的地址路徑。
例子:
當前頁爲:http://www.test.com/home.php?id=23&cid=22
echo $_SERVER["REQUEST_URI"]
結果爲:/home.php?id=23&cid=22
4、parse_url()解析URL函數
parse_url() 是講URL解析成有固定鍵值的數組的函數
例子
$ua=parse_url("http://username:password@hostname/path?arg=value#anchor");
print_r($ua);
結果:
Array
(
[scheme] => http ;協議
[host] => hostname ;主機域名
[user] => username ;用戶
[pass] => password ;密碼
[path] => /path ;路徑
[query] => arg=value ;取參數
[fragment] => anchor ;
)
5、代碼實例
這個一個留言的分頁,分爲3個部分,一個是數據庫設計,一個是鏈接頁面,一個是顯示頁面。
(1)設計數據庫
設計數據庫名爲bbs,有一個數據表爲message,裏面包含title,lastdate,user,content等字段,分別表示留言標題,留言日前,留言人,留言的內容
(2)鏈接頁面
<?php
$conn = @ mysql_connect("localhost", "root", "123456") or die("數據庫連接錯誤");
mysql_select_db("bbs", $conn);
mysql_query("set names 'GBK'"); //使用GBK中文編碼;
//將空格,換行轉換爲HTML可解析
function htmtocode($content) {
$content = str_replace("\n", "<br>", str_replace(" ", " ", $content)); //兩個str_replace嵌套
return $content;
}
//$content=str_replace("'","‘",$content);
//htmlspecialchars();
?>
(3)顯示頁面
<?php
include("conn.php");
$pagesize=2; //設置每頁顯示2個記錄
$url=$_SERVER["REQUEST_URI"];
$url=parse_url($url);
$url=$url[path];
$numq=mysql_query("SELECT * FROM `message`");
$num = mysql_num_rows($numq);
if($_GET[page]){
$pageval=$_GET[page];
$page=($pageval-1)*$pagesize;
$page.=',';
}
if($num > $pagesize){
if($pageval<=1)$pageval=1;
echo "共 $num 條".
" <a href=$url?page=".($pageval-1).">上一頁</a> <a href=$url?page=".($pageval+1).">下一頁</a>";
}
$SQL="SELECT * FROM `message` limit $page $pagesize ";
$query=mysql_query($SQL);
while($row=mysql_fetch_array($query)){
?>
<table width=500 border="0" cellpadding="5" cellspacing="1" bgcolor="#add3ef">
<tr bgcolor="#eff3ff">
<td>標題:<?php echo $row[title]?></td> <td>時間:<?php echo $row[lastdate]?></td>
</tr>
<tr bgcolor="#eff3ff">
<td> 用戶:<?php echo $row[user]?></td><td></td>
</tr>
<tr>
<td>內容:<?php echo htmtocode($row[content]);?></td>
</tr>
<br>
</table>
<?php } ?>