PHP+MYSQL分頁原理
專注于為中小企業提供成都網站設計、做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業柳州免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了數千家企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。
1、 sql語句中的limit用法
2、 學習分頁的一種公式
(1) 分頁原理
所謂的分頁顯示,也就是將數據庫中的結果集,以一定的條數顯示出來。
(2) 如何分段(以10條數據為單位)
前10條記錄:
第11條到20條:
第21條到30條:
(3) 得到公式
(當前頁數-1)*每頁條數,每頁條數
3、 實例代碼
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
include
("./config/conn.php");
$sql="select
*
from
ly
order
by
id
desc";
$result=mysql_query($sql);
$num=mysql_num_rows($result);
//統計行數
$pages=ceil($num/5);
//總頁數
$page=$_GET['page'];
//獲得page,如果沒有設置或者page=0,把$page=1;
if(!isset($page)
||
$page==0)
$page=1;
$start=($page-1)*5;
$sql="select
*
from
ly
order
by
id
desc
limit
$start,5";
mysql_query($sql);
if($sumpage!=0)
{
if($page!=1)
{
echo
"a
href=$PHP_SELF?page=1首頁/a\t";
}else
{
echo
"首頁\t";
}
if($page1)
{
echo
"a
href=$PHP_SELF?page=".($page-1)."上一頁/a\t";
}else
{
echo
"上一頁\t";
}
if($page$pages)
{
echo
"a
href=$PHP_SELF?page=".($page+1)."下一頁/a\t";
}else
{
echo
"下一頁\t";
}
if($page!=$pages)
{
echo
"a
href=$PHP_SELF?page=".$pages."尾頁/a\t";
}else
{
echo
"尾頁\t";
}
}else
{
echo
"目前沒有記錄!!";
}
?php
include("connection.php");
$perNumber=10; //每頁顯示的記錄數
$page=$_GET['page']; //獲得當前的頁面值
$count=mysql_query("select count(*) from user"); //獲得記錄總數
$rs=mysql_fetch_array($count);
$totalNumber=$rs[0];
$totalPage=ceil($totalNumber/$perNumber); //計算出總頁數
if (!isset($page)) {
$page=1;
} //如果沒有值,則賦值1
$startCount=($page-1)*$perNumber; //分頁開始,根據此方法計算出開始的記錄
$result=mysql_query("select * from user limit $startCount,$perNumber"); //根據前面的計算出開始的記錄和記錄數
while ($row=mysql_fetch_array($result)) {
echo "user_id:".$row[0]."br";
echo "username:".$row[1]."br"; //顯示數據庫的內容
}
if ($page != 1) { //頁數不等于1
?
a href="fenye.php?page=?php echo $page - 1;?"上一頁/a !--顯示上一頁--
?php
}
for ($i=1;$i=$totalPage;$i++) { //循環顯示出頁面
?
a href="fenye.php?page=?php echo $i;?"?php echo $i ;?/a
?php
}
if ($page$totalPage) { //如果page小于總頁數,顯示下一頁鏈接
?
a href="fenye.php?page=?php echo $page + 1;?"下一頁/a
?php
}
?
================================
這個是很簡單的..而且也寫了注釋..不知道合不合你的意..
網站名稱:php分頁顯示數據源碼 php分頁顯示數據源碼不正確
URL標題:http://vcdvsql.cn/article30/doooeso.html
成都網站建設公司_創新互聯,為您提供手機網站建設、全網營銷推廣、品牌網站建設、網站內鏈、電子商務、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯