首頁 後端開發 php教程 如何把查询和分页一起实现

如何把查询和分页一起实现

Jun 13, 2016 am 11:54 AM
keys nbsp page

怎么把查询和分页一起实现

本帖最后由 u014474944 于 2014-04-04 20:14:27 编辑 查询 和 分页都能实现 就是不知道怎么把两个合在一起 
代码如下
<br />$page=isset($_GET['page'])?$_GET['page']:1; <br />$pagesize=20; <br />$sql="SELECT count(*) from khxx";<br />$res=mysql_query($sql);<br />$maxrows=mysql_result($res,0,0);<br />$maxpages=ceil($maxrows/$pagesize);<br />if($page>$maxpages){<br />	$page=$maxpages;}<br />if($page<1){<br />	$page=1;}<br />$limit=" limit ".(($page-1)*$pagesize).",{$pagesize}";<br /><br />if (!empty($_GET[keys])) {<br />			$keys=$_GET['keys'];<br />			$ww="`dates` like '%".$keys."%' or `area` like '%".$keys."%' ;<br />			$wh="where {$ww}";<br />		}<br />
登入後複製

<br />		<form action="khall.php" method="get"><br />			<input class="inp" type="text" name="keys"/ ><br />			<input class="sub" type="submit" value="查询"/><br />		</form><br />			</tr><br />			<tr><br />			<?php echo "当前{$page}/{$maxpages}页 共计{$maxrows}条";<br />					  echo "<a href='khall.php?page=1'>首页</a>";<br />					  echo "<a href='khall.php?page=".($page-1)."'>上一页</a>";<br />					  echo "<a href='khall.php?page=".($page+1)."'>下一页</a>";<br />					  echo "<a href='khall.php?page={$maxpages}'>末页</a>";<br />				?><br />                       </tr><br />
登入後複製

<?php<br />			<br />			$sql="SELECT * FROM `khxx` {$wh} order by id desc {$limit}";<br />			$query=mysql_query($sql);<br />			while ($rs=mysql_fetch_array($query)){<br />		?><br /><br />
登入後複製

------解决方案--------------------
还要怎么整合?
sql查询的就是当前页的内容。也就是说,你只需要把当前页查询出来的内容展示出来,然后编好页码就行了。
------解决方案--------------------
<br /><?php<br />$page=isset($_GET['page'])?$_GET['page']:1; <br />$pagesize=20; <br /><br />if (!empty($_GET[keys])) {<br />   $keys=$_GET['keys'];<br />   $ww="`dates` like '%".$keys."%' or `area` like '%".$keys."%' ";<br />   $wh="where {$ww}";<br />}else{<br />    $wh = ""<br />}<br /><br />$sql="SELECT count(*) from khxx ".$wh; // 计算总数时加入搜索条件 <br />$res=mysql_query($sql);<br />$maxrows=mysql_result($res,0,0);<br />$maxpages=ceil($maxrows/$pagesize);<br />if($page>$maxpages){<br />    $page=$maxpages;}<br />if($page<1){<br />    $page=1;}<br />$limit=" limit ".(($page-1)*$pagesize).",{$pagesize}";<br /><br />// 查询当前页记录 <br />$sql="SELECT * FROM `khxx` {$wh} order by id desc {$limit}";<br />$query=mysql_query($sql);<br />while ($rs=mysql_fetch_array($query)){<br /><br />?><br />
登入後複製
登入後複製

------解决方案--------------------
你得把搜索的字段 写进URL里面 然后传参 那样才行吧
------解决方案--------------------
你的翻页条中没有附加查询条件
------解决方案--------------------
引用:
Quote: 引用:

你得把搜索的字段 写进URL里面 然后传参 那样才行吧

就是不知道怎么写 没思路


echo "<a href='khall.php?keys=$_GET['keys']&page=".($page-1)."'>上一页</a>";
登入後複製

你把分页URL上都加上 这个 查询字段 应该就可以了
------解决方案--------------------
引用:
Quote: 引用:

<br /><?php<br />$page=isset($_GET['page'])?$_GET['page']:1; <br />$pagesize=20; <br /><br />if (!empty($_GET[keys])) {<br />   $keys=$_GET['keys'];<br />   $ww="`dates` like '%".$keys."%' or `area` like '%".$keys."%' ";<br />   $wh="where {$ww}";<br />}else{<br />    $wh = ""<br />}<br /><br />$sql="SELECT count(*) from khxx ".$wh; // 计算总数时加入搜索条件 <br />$res=mysql_query($sql);<br />$maxrows=mysql_result($res,0,0);<br />$maxpages=ceil($maxrows/$pagesize);<br />if($page>$maxpages){<br />    $page=$maxpages;}<br />if($page<1){<br />    $page=1;}<br />$limit=" limit ".(($page-1)*$pagesize).",{$pagesize}";<br /><br />// 查询当前页记录 <br />$sql="SELECT * FROM `khxx` {$wh} order by id desc {$limit}";<br />$query=mysql_query($sql);<br />while ($rs=mysql_fetch_array($query)){<br /><br />?><br />
登入後複製
登入後複製

效果和我写的差不多 
我写的有个问题就是 点下一页后 当前的查询状态就消失了 想问下 怎么写才可以把查询加入到分页

那你需要在翻頁的url中加入条件参数,例如下一页需要这样写
echo "下一页";
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

解決方法:您的組織要求您更改 PIN 碼 解決方法:您的組織要求您更改 PIN 碼 Oct 04, 2023 pm 05:45 PM

解決方法:您的組織要求您更改 PIN 碼

Windows 11 上調整視窗邊框設定的方法:變更顏色和大小 Windows 11 上調整視窗邊框設定的方法:變更顏色和大小 Sep 22, 2023 am 11:37 AM

Windows 11 上調整視窗邊框設定的方法:變更顏色和大小

如何在 Windows 11 上變更標題列顏色? 如何在 Windows 11 上變更標題列顏色? Sep 14, 2023 pm 03:33 PM

如何在 Windows 11 上變更標題列顏色?

OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題 OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題 Jul 16, 2023 pm 03:29 PM

OOBELANGUAGE錯誤Windows 11 / 10修復中出現問題的問題

Windows 11 上啟用或停用工作列縮圖預覽的方法 Windows 11 上啟用或停用工作列縮圖預覽的方法 Sep 15, 2023 pm 03:57 PM

Windows 11 上啟用或停用工作列縮圖預覽的方法

Windows 11 上的顯示縮放比例調整指南 Windows 11 上的顯示縮放比例調整指南 Sep 19, 2023 pm 06:45 PM

Windows 11 上的顯示縮放比例調整指南

10種在 Windows 11 上調整亮度的方法 10種在 Windows 11 上調整亮度的方法 Dec 18, 2023 pm 02:21 PM

10種在 Windows 11 上調整亮度的方法

如何在Safari中關閉iPhone的隱私瀏覽身份驗證? 如何在Safari中關閉iPhone的隱私瀏覽身份驗證? Nov 29, 2023 pm 11:21 PM

如何在Safari中關閉iPhone的隱私瀏覽身份驗證?

See all articles