PHP分页问题,请大神现身!分页代码页书显示正确,但每页显示重复内容。
数据库内共有1287条记录,设置每页显示1000条,每行显示9条。
但结果一页里就把所有记录1~1287都显示了,第二页也是1~1287.
分页数是正确的2页,
哪里出了问题请各位帮忙看下代码,十分感谢!
代码如下:
<?php <br />$page = $_GET["page"]; <br />function Page($rows,$page_size){ <br />global $page,$select_from,$select_limit,$pagenav; <br />$page_count = ceil($rows/$page_size); <br />if($page <= 1 || $page == '') $page = 1; <br />if($page >= $page_count) $page = $page_count; <br />$select_limit = $page_size; <br />$select_from = ($page - 1) * $page_size.','; <br />$pre_page = ($page == 1)? 1 : $page - 1; <br />$next_page= ($page == $page_count)? $page_count : $page + 1 ; <br />$pagenav .= "第 $page/$page_count 页 共 $rows 条记录 "; <br />$pagenav .= "<a href='?page=1'>首页</a> "; <br />$pagenav .= "<a href='?page=$pre_page'>前一页</a> "; <br />$pagenav .= "<a href='?page=$next_page'>后一页</a> "; <br />$pagenav .= "<a href='?page=$page_count'>末页</a>"; <br />$pagenav.=" 跳到<select name='topage' size='1' onchange='window.location=\"?page=\"+this.value'>\n"; <br />for($i=1;$i<=$page_count;$i++){ <br />if($i==$page) $pagenav.="<option value='$i' selected>$i</option>\n"; <br />else $pagenav.="<option value='$i'>$i</option>\n"; <br />} <br />} <br />$conn = mysql_connect('127.0.0.1:8889', 'root', 'root');<br />mysql_select_db('test3', $conn);<br />$rows = mysql_num_rows(mysql_query("select * from cp")); <br />$sql="select * from cp";<br />$r = mysql_query($sql);<br />Page($rows,1000); <br />$s = "select * from cp limit 0,1000"; <br />$rst = mysql_query($s); <br />$row = mysql_fetch_array($rst); <br />?><br /><table border="1" ><br /><?php<br /><br /> $k=1;<br /> while($rs = mysql_fetch_assoc($r))<br /> {<br /> $color=$rs["count"] >= "3"?"#999999":"white";<br /> echo $k%9==1?"<tr>":"";<br />?><br /> <td bgcolor="#3399FF"><?php echo $rs["id"];?></td><br /> <td bgcolor="<?php echo $color;?>"><?php echo $rs["cp"];?></td><br /> <td bgcolor="<?php echo $color;?>"><?php echo $rs["count"];?></td><br /><?php<br /> echo $k%9==0?"</tr>":"";<br /> $k++;<br /> }<br /><br />?><br /><?php<br />echo $pagenav;<br /><br />?><br /></table>



------解决思路----------------------
你的查询串是 $s?=?"select?*?from?cp?limit?0,1000";
无论 $_GET["page"] 是什么,那个 0 总是不会变的,当然是每页都显示相同的结果啦
查询的起始偏移应该是与 $_GET["page"] 相关的数字
对于你的情况就是 ($_GET["page"] - 1) * 1000
------解决思路----------------------
<br /><br /><?php <br />$page = $_GET["page"]; <br />function Page($rows,$page_size){ <br />global $page,$select_from,$select_limit,$pagenav; <br />$page_count = ceil($rows/$page_size); <br />if($page <= 1 <br><font color='#FF8000'>------解决思路----------------------</font><br> $page == '') $page = 1; <br />if($page >= $page_count) $page = $page_count; <br />$select_limit = $page_size; <br />$select_from = ($page - 1) * $page_size.','; <br />$pre_page = ($page == 1)? 1 : $page - 1; <br />$next_page= ($page == $page_count)? $page_count : $page + 1 ; <br />$pagenav .= "第 $page/$page_count 页 共 $rows 条记录 "; <br />$pagenav .= "<a href='?page=1'>首页</a> "; <br />$pagenav .= "<a href='?page=$pre_page'>前一页</a> "; <br />$pagenav .= "<a href='?page=$next_page'>后一页</a> "; <br />$pagenav .= "<a href='?page=$page_count'>末页</a>"; <br />$pagenav.=" 跳到<select name='topage' size='1' onchange='window.location=\"?page=\"+this.value'>\n"; <br />for($i=1;$i<=$page_count;$i++){ <br />if($i==$page) $pagenav.="<option value='$i' selected>$i</option>\n"; <br />else $pagenav.="<option value='$i'>$i</option>\n"; <br />} <br />} <br />$conn = mysql_connect('127.0.0.1:8889', 'root', 'root');<br />mysql_select_db('test3', $conn);<br />$rows = mysql_num_rows(mysql_query("select * from cp")); <br />///@@这段帮你添加的<br /> $limit_start=($page-1)*1000;<br /> $s = "select * from cp limit $limit_start,1000"; <br />///@@<br /><br />$sql="select * from cp";<br />$r = mysql_query($s);<br />Page($rows,1000); <br />//$s = "select * from cp limit 0,1000"; <br />//$rst = mysql_query($s); <br />//$row = mysql_fetch_array($rst); <br />?><br /><table border="1" ><br /><?php<br /> <br /> $k=1;<br /> while($rs = mysql_fetch_assoc($r))<br /> {<br /> $color=$rs["count"] >= "3"?"#999999":"white";<br /> echo $k%9==1?"<tr>":"";<br />?><br /> <td bgcolor="#3399FF"><?php echo $rs["id"];?></td><br /> <td bgcolor="<?php echo $color;?>"><?php echo $rs["cp"];?></td><br /> <td bgcolor="<?php echo $color;?>"><?php echo $rs["count"];?></td><br /><?php<br /> echo $k%9==0?"</tr>":"";<br /> $k++;<br /> }<br /> <br />?><br /><?php<br />echo $pagenav;<br /> <br />?><br /></table><br />
------解决思路----------------------
<br /><br />$sql="select * from cp limit ".($page-1)*1000.",1000";<br />$r = mysql_query($sql);<br />Page($rows,1000); <br />//$s = "select * from cp limit 0,1000"; <br />//$rst = mysql_query($s); <br />//$row = mysql_fetch_array($rst); <br />上面三行你都没用到,注释掉<br />$sql修改一下,你下面循环用到的是$r对应的sql语句<br />所以一直是一样的<br />

DependencyInjection(DI)inPHPenhancescodeflexibilityandtestabilitybydecouplingdependencycreationfromusage.ToimplementDIeffectively:1)UseDIcontainersjudiciouslytoavoidover-engineering.2)Avoidconstructoroverloadbylimitingdependenciestothreeorfour.3)Adhe

到Improveyourphpwebsite的實力,UsEthestertate:1)emplastOpCodeCachingWithOpcachetCachetOspeedUpScriptInterpretation.2)優化的atabasequesquesquesquelies berselectingOnlynlynnellynnessaryfields.3)usecachingsystemssslikeremememememcachedisemcachedtoredtoredtoredsatabaseloadch.4)

是的,ItispossibletosendMassemailswithp.1)uselibrarieslikeLikePhpMailerorSwiftMailerForeffitedEmailsending.2)enasledeLaysBetenemailstoavoidSpamflagssspamflags.3))

DependencyInjection(DI)inPHPisadesignpatternthatachievesInversionofControl(IoC)byallowingdependenciestobeinjectedintoclasses,enhancingmodularity,testability,andflexibility.DIdecouplesclassesfromspecificimplementations,makingcodemoremanageableandadapt

使用PHP發送電子郵件的最佳方法包括:1.使用PHP的mail()函數進行基本發送;2.使用PHPMailer庫發送更複雜的HTML郵件;3.使用SendGrid等事務性郵件服務提高可靠性和分析能力。通過這些方法,可以確保郵件不僅到達收件箱,還能吸引收件人。

計算PHP多維數組的元素總數可以使用遞歸或迭代方法。 1.遞歸方法通過遍歷數組並遞歸處理嵌套數組來計數。 2.迭代方法使用棧來模擬遞歸,避免深度問題。 3.array_walk_recursive函數也能實現,但需手動計數。

在PHP中,do-while循環的特點是保證循環體至少執行一次,然後再根據條件決定是否繼續循環。 1)它在條件檢查之前執行循環體,適合需要確保操作至少執行一次的場景,如用戶輸入驗證和菜單系統。 2)然而,do-while循環的語法可能導致新手困惑,且可能增加不必要的性能開銷。

在PHP中高效地哈希字符串可以使用以下方法:1.使用md5函數進行快速哈希,但不適合密碼存儲。 2.使用sha256函數提高安全性。 3.使用password_hash函數處理密碼,提供最高安全性和便捷性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具