1、前言
分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解,力求让看完这篇文章的朋友在看完以后对于分页显示的原理和实现方法有所了解。本文适合初学者阅读,所有示例代码均使用php编写。
2、原理
所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:
每页多少条记录($PageSize)?
当前是第几页($CurrentPageID)?
现在只要再给我一个结果集,我就可以显示某段特定的结果出来。
至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
以mysql数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率。
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
……
这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板:
select * from table limit ($CurrentPageID – 1) * $PageSize, $PageSize
拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。以下我将用具体代码加以说明。
3、简单代码
请详细阅读以下代码,自己调试运行一次,最好把它修改一次,加上自己的功能,比如搜索等等。
// 建立数据库连接
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("Could not connect: " . mysql_error());
// 获取当前页数
if( isset($_GET[‘page’]) ){
$page = intval( $_GET[‘page’] );
}
else{
$page = 1;
}
// 每页数量
$PageSize = 10;
// 获取总数据量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row[‘amount’];
// 记算总共有多少页
if( $amount ){
if( $amount < $page_size ){ $page_count = 1; } //如果总数据量小于$PageSize,那么只有一页
if( $amount % $page_size ){ //取总数据量除以每页数的余数
$page_count = (int)($amount / $page_size) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
}else{
$page_count = $amount / $page_size; //如果没有余数,则页数等于总数据量除以每页数的结果
}
}
else{
$page_count = 0;
}
// 翻页链接
$page_string = ”;
if( $page == 1 ){
$page_string .= ‘第一页|上一页|’;
}
else{
$page_string .= ‘<a href="/?page=1>";第一页</a>|<a href="/?page=’."($page-1).’>上一页</a>|’;
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= ‘下一页|尾页’;
}
else{
$page_string .= ‘<a href="/?page=’."($page+1).’>下一页</a>|<a href="/?page=’."$page_count.’>尾页</a>’;
}
// 获取数据,以二维数组格式返回结果
if( $amount ){
$sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
$result = mysql_query($sql);
while ( $row = mysql_fetch_row($result) ){
$rowset[] = $row;
}
}else{
$rowset = array();
}
// 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果
?>
波比源码 » 分析PHP的分页原理 附:简单实例
purchase levofloxacin generic levaquin us
avodart 0.5mg generic dutasteride pills ondansetron online order
spironolactone online buy order generic diflucan 200mg diflucan 200mg generic
ampicillin 250mg oral order erythromycin pills erythromycin 250mg cost
order sildenafil online cheap purchase bimatoprost generic buy robaxin 500mg sale
order lamotrigine without prescription prazosin 2mg tablet order tretinoin cream sale
tadalafil 10mg ca order avanafil pill buy voltaren pill
buy accutane 20mg online cheap buy isotretinoin generic order azithromycin 250mg generic
order indomethacin pill cheap lamisil 250mg buy amoxicillin 250mg generic
deltasone 10mg canada buy sildenafil 100mg for sale sildenafil 100mg usa
buy alendronate pill order ibuprofen 600mg online pepcid 40mg pill
order tacrolimus 1mg sale trandate 100 mg over the counter ursodiol generic
purchase imdur telmisartan price buy micardis 80mg generic
tadalafil dosage cost cialis order symmetrel 100 mg online cheap
purchase dapsone pills buy avlosulfon generic order perindopril 4mg online
buy modafinil sale buy stromectol 6mg online cheap how much does ivermectin cost
luvox online cymbalta 20mg us glucotrol 10mg tablet
accutane 10mg oral order accutane generic prednisone 5mg drug
brand tadalafil 40mg tadalafil 10mg cheap purchase sildenafil sale
cheap furosemide 100mg buy doxycycline online plaquenil 400mg tablet
order cialis 5mg pills clomipramine 50mg sale clomipramine 25mg over the counter
glycomet for sale online cialis usa buy cialis online
olanzapine over the counter bystolic 20mg pills order diovan 80mg sale
sildenafil india viagra sildenafil 200mg order lisinopril 10mg online cheap
buy prilosec without prescription order generic omeprazole online casinos for usa players
order zyvox 600 mg online cheap best online gambling slot games free
essay writing slot games free online casinos usa
write essays for me online assignment help viagra 100mg drug
order generic aristocort aristocort 4mg pills order desloratadine 5mg online cheap
order priligy 30mg buy cytotec online cheap synthroid sale
buy cialis 40mg generic buy cialis 40mg online cheap viagra mail order
brand xenical 120mg diltiazem 180mg without prescription zovirax 400mg ca
imitrex 50mg price order levofloxacin 250mg without prescription dutasteride drug
buy metronidazole 200mg online buy generic flagyl 200mg bactrim 960mg over the counter
order cephalexin online cheap buy keflex 250mg online cheap buy erythromycin 250mg generic
cash poker online online blackjack for real money purchase cialis pill
trazodone 50mg brand buy generic trazodone 100mg buy sildenafil 50mg pill
generic sildenafil 50mg purchase tadalafil without prescription cialis 5mg
play blackjack online best gambling sites buy generic cialis 10mg
zithromax 250mg pills order prednisolone 10mg online neurontin buy online
hard rock casino online buy modafinil 100mg online modafinil online order
order lasix online cheap buy hydroxychloroquine 400mg generic plaquenil over the counter
order deltasone 10mg generic minipress 2mg usa mebendazole us
order sildenafil 100mg online cheap order fildena 50mg purchase budesonide sale
buy retin cream generic order retin cream online avanafil 100mg generic
tadacip 20mg generic tadalafil buy online indomethacin 75mg cheap
biaxin pills biaxin pills meclizine pills
buy tiotropium bromide 9mcg pill hytrin 5mg brand oral terazosin 5mg
buy singulair without prescription singulair pill sildenafil 50mg cost
guaranteed cialis overnight delivery usa cost tadalafil 40mg real cialis pharmacy prescription
stromectol ivermectin buy stromectol 12mg generic brand avlosulfon 100mg
slots meaning best slots to play online play online blackjack for real money
altace 10mg for sale buy arcoxia 120mg order etoricoxib pills
order asacol 400mg pills purchase azelastine sprayer avapro 300mg pill
benicar generic olmesartan 10mg usa depakote 500mg us
order clobetasol cream order buspar 10mg pills brand cordarone 100mg
order amoxil 1000mg generic amoxil 500mg canada ivermectin topical
buy priligy 60mg generic avana order generic domperidone 10mg
buy ropinirole 2mg for sale order requip 1mg for sale order trandate generic
order fenofibrate 200mg for sale viagra sildenafil 150mg purchase sildenafil pills
esomeprazole 40mg over the counter order furosemide 40mg sale order lasix 40mg online cheap
buy minocycline for sale buy minocin 50mg sale purchase hytrin online
Hi, just required you to know I he added your site to my Google bookmarks due to your layout. But seriously, I believe your internet site has 1 in the freshest theme I??ve came across. Metropol Halı Karaca Halı Öztekin ve Selçuklu Halı Cami Halısı ve Cami Halıları Türkiye’nin En Büyük Cami Halısı Fabrikasıyız…
glucophage cost buy verapamil without prescription cost tamoxifen 10mg
purchase serophene for sale buy atorvastatin 80mg sale prednisolone 20mg canada
isotretinoin 10mg oral prednisone 40mg without prescription buy ampicillin 250mg for sale
order sildenafil 100mg for sale propecia 5mg tablet buy propecia 5mg generic
stromectol ivermectin deltasone 10mg price buy deltasone 5mg generic
brand accutane order amoxil 500mg generic brand zithromax
prednisolone canada lasix canada furosemide uk
doxycycline over the counter buy acyclovir 400mg pill oral acyclovir
cheap imuran 25mg order imuran generic naproxen uk
Good info. Lucky me I reach on your website by accident, I bookmarked it. Cepbahis
order zocor 20mg for sale generic sildalis buy sildalis
Еще одно полезное правило, а именно: дела, неугодные подданным, государи
должны возлагать на других, а
угодные – исполнять сами.
В заключение же повторю, что государю
надлежит выказывать к знати почтение, но не
вызывать ненависти в народе.
5 способов вернуть интерес к работе и увлечениям
buy alfuzosin online cheap diltiazem 180mg canada buy diltiazem sale
coumadin 2mg canada generic reglan purchase zyloprim pill
cetirizine pills sertraline 100mg sale buy sertraline 50mg pill
buy generic cenforce buy metformin generic buy metformin 1000mg online cheap
poip-nsk.ru
methotrexate 5mg tablet reglan 20mg drug brand metoclopramide
purchase imitrex generic sumatriptan tablet buy generic avodart
fond-detym.ru
nebivolol 20mg price order diovan without prescription clozaril 50mg generic
buy metronidazole generic order keflex without prescription order cephalexin 250mg pill
vermox generic buy retin cream for sale buy tadalafil 20mg without prescription
cleocin 150mg pill order erythromycin pills cheap erectile dysfunction pills online
order avanafil sale buy generic tadalafil 10mg buy voltaren 100mg pills
generic indocin 50mg buy indocin paypal buy generic cefixime
catapres 0.1mg pills buy generic catapres tiotropium bromide 9mcg ca
minocin 50mg ca buy terazosin paypal purchase pioglitazone generic
arava 20mg canada purchase azulfidine for sale order azulfidine 500 mg pills
buy generic tadalafil 20mg order tadalafil 10mg cialis 10mg cheap
ivermectin 3mg over the counter stromectol 12mg uk prednisone 40mg sale
azithromycin 250mg drug azithromycin pills buy neurontin 800mg sale
brand lasix 100mg order monodox pills albuterol ca
vardenafil 20mg tablet hydroxychloroquine cheap order plaquenil pills
order olmesartan 20mg online cheap depakote 500mg price where can i buy depakote
buy generic temovate for sale order generic cordarone 200mg buy cordarone 200mg pills
order generic digoxin 250 mg order molnunat 200mg pills molnupiravir oral