① PHP分頁sql語句
mysql_query("SELECT * FROM gb_content order by id desc limit " .$limit. ','.$lines.'')
後面的limit是控制頁面的內容,也就是假如一頁10個
第一頁 開始1-10
第二 開始 11-10
第三 開始 21 -10
② php mysql查詢結果分頁顯示
<?php
$mysql_server_name="localhost";
$mysql_username='root';
$mysql_password='';
$mysql_database='hp';
$conn=mysql_connect($mysql_server_name,$mysql_username,$mysql_password);
@mysql_connect("localhost","root","")ordie("資料庫連接失敗");
@mysql_select_db("hp")ordie("資料庫不存在");
mysql_query("setnamesutf8");
$pagesize=$_GET['pagesize']>0?$_GET['pagesize']:10;//默認情況下每頁顯示10條數據
$pagenum=$_GET['pagenum']>0?$_GET['pagenum']:0;
$query_start=$pagesize*$pagenum;
if($_POST['submit']){
$strsql_add='';
$strsql_add.=$_POST['idc']?"andidc='$_POST[idc]'":"";
$strsql_add.=$_POST['jiguihao']?"andjiguihao='$_POST[jiguihao]'":"";
$strsql_add.=$_POST['neicun']?"andneicun='$_POST[neicun]'":"";
$strsql_add.=$_POST['yingpan']?"andyingpan='$_POST[yingpan]'":"";
$strsql_add.=$_POST['xinghao']?"andxinghao='$_POST[xinghao]'":"";
$strsql_add.=$_POST['cpu']?"andcpu='$_POST[cpu]'":"";
$strsql_add.=$_POST['guishu']?"andguishu='$_POST[guishu]'":"";
$strsql_add.=$_POST['ip']?"andip='$_POST[ip]'":"";
}
$strsql="select*fromzichanwhere1=1$strsql_addlimit$query_start,$pagesize";
$result=mysql_db_query($mysql_database,$strsql,$conn);
$row=mysql_fetch_row($result);
$nextpage_num=$pagenum++;
$lastpage_num=ceil(count($row)/$pagesize);
echo'<fontface="verdana">';
echo'<tableborder="1"cellpadding="1"cellspacing="2">';
//顯示欄位名稱
echo"</b><tr></b>";
for($i=0;$i<mysql_num_fields($result);$i++)
{
echo'<tdbgcolor="#00FF00"><b>'.
mysql_field_name($result,$i);
echo"</b></td></b>";
}
echo"</tr></b>";
//定位到第一條記錄
mysql_data_seek($result,0);
//循環取出記錄
while($row=mysql_fetch_row($result))
{
echo"<tr></b>";
for($i=0;$i<mysql_num_fields($result);$i++)
{
echo'<tdbgcolor="#00FF00">';
echo$row[$i];
echo'</td>';
}
echo'<td><ahref='xiugai.php?id='.$row[0].''>修改</a>';
echo'</td>';
echo'<td><ahref="javascript:void(0)"onclick="if(window.confirm('確認刪除?')){window.location.href='del.php?id='.$row[0].''}">刪除</a>';
echo'</td>';
echo"</tr></b>";
}
echo"</table></b>";
echo"</font>";
//釋放資源
mysql_free_result($result);
//關閉連接
mysql_close($conn);
?>
html頁面要增加的參數:
首頁 增加 &pagenum=0 或者 不加
下一頁 &pagenum= $nextpage_num
尾頁 &pagenum= $lastpage_num
③ 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 連接MS SQL 2000資料庫,如何實現分頁
SELECT
TOP
25
*
FROM
(SELECT
*
FROM
表名
WHERE
條件)
T
WHERE
(主鍵
NOT
IN
(SELECT
TOP
通過PHP計數值(每頁條數
*
(當前頁
-
1)
)
主鍵
FROM
(SELECT
*
FROM
表名
WHERE
條件)
T2
ORDER
BY
T2.主鍵
DESC))
上面SELECT
*
FROM
表名
WHERE
條件有兩句,這兩句就是你查詢時真正的SQL語句
你可以寫個存儲過程,或寫個PHP函數
⑤ php sql語句請教 關於分頁功能的
select * from article limit ". ($page-1)*$page_size.",$page_size
⑥ PHP和MYSQL查詢和分頁顯示
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>無標題文檔</title>
</head>
<body>
<!--分頁開始-->
<?php
if(isset($_GET['page'])) //由GET方法獲得頁面傳入當前頁數的參數
{
$page = $_GET['page'];
}
else
{
$page = 1;
}
$page_size = 2; //每頁顯示兩條數據
//獲取數據總量
$db_host = 'localhost'; //資料庫主機
$db_user = 'tianchunli';//資料庫用戶帳戶
$db_passw = '58816828'; //資料庫帳戶密碼
$db_name = 'jiaoyou' ;//資料庫名稱
//連接資料庫
$conn=mysql_connect($db_host,$db_user,$db_passw) or die("資料庫連接失敗!");
//設置字元集,如utf8和gbk等, 根據資料庫的字元集而定
mysql_query("set names gb2312");
//選定資料庫
mysql_select_db($db_name,$conn) or die('資料庫選定失敗!');
$xuesheng_xm =$_POST[xuesheng_xm];//對應姓名
$xuesheng_xb =$_POST[xuesheng_xb];//對應性別
$xuesheng_sg1=$_POST[xuesheng_sg1];//對應最低身高
$xuesheng_sg2=$_POST[xuesheng_sg2];//對應最高身高
$sql = "select * from biao1 where 1=1";
if($xuesheng_xm !=''){
$sql .= " and xuesheng_xm like '%$xuesheng_xm%' ";
}
if($xuesheng_xb !=''){
$sql .= " and xuesheng_xb = $xuesheng_xb ";
}
if($xuesheng_sg1 != -1 && $xuesheng_sg2 != -1){
$sql .= " and xuesheng_sg between $xuesheng_sg1 and $xuesheng_sg2 ";
}
$result=mysql_query($sql);
$total = mysql_num_rows($result);
$start=($page-1)*$pageSize;
$result = mysql_query($sql);
//echo $total;
//開始計算總頁數
if($total)
{
if($total < $page_size)
$page_count = 1;
if($total % $page_size)
{
$page_count = (int)($total/$page_size) + 1;
}
else
{
$page_count = $total/$page_size;
}
}
else
{
$page_count = 0;
}
//翻頁鏈接
$turn_page = '';
if($page == 1)
{
$turn_page .= '首頁 | 上一頁 | ';
}
else
{
$turn_page .= '<a href=2.php?page=1> 首頁</a> | <a href=2.php?page='.($page-1).'>上一頁</a> | ';
}
if($page == $page_count || $page_count == 0)
{
$turn_page .= '下一頁 | 尾頁';
}
else
{
$turn_page .= '<a href=2.php?page='.($page+1).'>下一頁</a> | <a href=2.php?page='.$page_count.'>尾頁</a>';
}
$sql = $sql." limit ". ($page-1)*$page_size .", ".$page_size;
echo $sql;
$result = mysql_query($sql);
?>
<?php
while($row = mysql_fetch_array($result))
{
echo $row['xuesheng_xm'];
}
?>
<br />
<?php echo $turn_page?>
</body>
</html>
這個,數據查詢語句根據你自己的需要改吧!我是用我自己建立的資料庫
⑦ PHP 查詢結果分頁顯示
信息太少 只能寫下面一部分
將while裡面改一下即可
<?php
$page_size=20;//每頁信息條數
//解析URL
$url=$_SERVER["REQUEST_URL"];
$url=parse_url($url);
$url=$url[path];
$numq=mysql_query("SELECT * FROM `表名`");
$num=mysql_num_rows($numq);
$page_first=1;
$page_last=ceil($num/$page_size);//獲得總頁數 也就是最後一頁的數值
if ($_GET[page]>=1){
$page_num=$_GET[page];
$page_nums=($page_num-1)*$page_size;
}else{
$page_num=1;
$page_nums=($page_num-1)*$page_size;
}
echo $num."條記錄,共".$page_last."頁"."====<b><big>這是第".$page_num."頁</big></b>"."<br>";
for($i=1;$i<=$page_last;$i++){
echo "<a href=$url2?page=".($page_num+$i-1).">"."第".($page_num+$i-1)."頁>> "."</a>";
}
$sql="SELECT * FROM `表名` limit $page_nums,$page_size";
$query=mysql_query($sql);
echo "<table border=1><tr ><th>姓名</th><th>姓別</th></tr>";
while($row=mysql_fetch_array($query)){
echo "<tr ><td>";
echo $row[name];
echo "</td>";
echo "<td>";
echo $row[sex];
echo "</td></tr>";
}
echo "</table>";
?>
⑧ 如何使用PHP做分頁查詢
做分頁查詢的處理頁面
<?phpinclude("DBDA.class.php");$db = new DBDA(); //查詢條件$tj1 = " 1=1 ";if(!empty($_GET["key"]))//獲取提交的關鍵字{ $tj1 = " areaname like '%{$_GET['key']}%'";} $sall = "select count(*) from chinastates where {$tj1}";//把條件拼接到語句中$total = $db->StrQuery($sall); include("page.class.php");$page = new Page($total,20); $sql = "select * from chinastates where {$tj1} ".$page->limit;//這里也要加上搜索條件$attr = $db->Query($sql); foreach($attr as $v){ echo "<tr><td>{$v[0]}</td><td>{$v[1]}</td><td>{$v[2]}</td></tr>";} ?>
⑨ PHP對查詢結果分頁,查詢結果的二次分頁
一般初學者在分頁的時候,遇到的問題是第一頁正常,下一頁的時候顯示了所有的數據。
其實原因很簡單,就是在下一頁的時候丟失了查詢條件,也就是在調用下一頁的時候,沒有搜索條件的相關變數傳遞下去。
找到了原因,處理就非常容易了。
我的建議是把搜索條件和跳轉的頁數結合起來,使得在搜索的時候可以指定頁、在頁面跳轉的時候也可以改變條件。假如你搜索的FORM是:
<form action=xxx.php>
<input type=text name=xx1>
<input type=text name=xx1>
......上面是你原來的搜索條件,增加下面一個頁數的變數......
<input type=text name=page value=1>
</form>
初始搜索用上面的代碼,下一頁也用上面的代碼,注意把變數的值傳遞過去,例如:
<input type=text name=xx1 value=