飘飘悠悠 发表于 2015-2-4 00:30:26

PHP网站制作之web开辟中PHP+MySQL分页显示示例剖析

通过这段时间的学习实践,对软件开发有了更多新的认识,不在局限于之前的片面性。当然,现在所学到的东西其实并不多,离当一个真正的程序员,还有很大的差距。mysql|web|分页|示例|显示       Web开辟是从此散布式程式开辟的主流,凡是的web开辟都要触及到与数据库打交道,客户端从办事器端读取凡是都是以分页的模式来显示,一页一页的浏览起来既便利又雅观。所以说写分页法式是web开辟的一个主要构成局部,在这里,咱们配合来研讨分页法式的编写。

  1、分页法式的道理

  分页法式有两个十分主要的参数:每页显示几笔记录($pagesize)和以后是第几页($page)。有了这两个参数就能够很便利的写出分页法式,咱们以MySql数据库作为数据源,在mysql里假如要想掏出表内某段特定内容可使用的 T-SQL语句:select * from table limit offset,rows来完成。这里的offset是纪录偏移量,它的盘算办法是offset=$pagesize*($page-1),rows是要显示的纪录条数,这里就是$page。也就是说select * from table limit 10,10这条语句的意思是掏出内外从第11笔记录入手下手的20笔记录。

  2、次要代码解析

$pagesize=10; //设置每页显示的纪录数
$conn=mysql_connect("localhost","root",""); //毗连数据库
$rs=mysql_query("select count(*) from tb_product",$conn); //获得纪录总数$rs
$myrow = mysql_fetch_array($rs);
$numrows=$myrow;

//盘算总页数

$pages=intval($numrows/$pagesize);

//判别页数设置

if (isset($_GET['page'])){
 $page=intval($_GET['page']);
}
else{
 $page=1; //不然,设置为第一页
}

  3、创立用例用表myTable

create table myTable(id int NOT NULL auto_increment,news_title varchar(50),news_cont text,add_time datetime,PRIMARY KEY(id))

  4、完全代码

<html>
<head>
<title>php分页示例</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<?php
 $conn=mysql_connect("localhost","root","");
 //设定每页显示的纪录数
 $pagesize=1;
 mysql_select_db("mydata",$conn);
 //获得纪录总数$rs,盘算总页数用
 $rs=mysql_query("select count(*) from tb_product",$conn);
 $myrow = mysql_fetch_array($rs);
 $numrows=$myrow;
 //盘算总页数

 $pages=intval($numrows/$pagesize);
 if ($numrows%$pagesize)
  $pages++;
 //设置页数
 if (isset($_GET['page'])){
  $page=intval($_GET['page']);
 }
 else{
  //设置为第一页
  $page=1;
 }
 //盘算纪录偏移量
 $offset=$pagesize*($page - 1);
 //读取指定纪录数
 $rs=mysql_query("select * from myTable order by id desc limit $offset,$pagesize",$conn);
 if ($myrow = mysql_fetch_array($rs))
 {
  $i=0;
  ?>
  <table border="0" width="80%">
  <tr>
   <td width="50%" bgcolor="#E0E0E0">
    <p align="center">题目</td>
    <td width="50%" bgcolor="#E0E0E0">
    <p align="center">宣布工夫</td>
  </tr>
  <?php
   do {
    $i++;
    ?>
  <tr>
   <td width="50%"><?=$myrow["news_title"]?></td>
   <td width="50%"><?=$myrow["news_cont"]?></td>
  </tr>
   <?php
   }
   while ($myrow = mysql_fetch_array($rs));
    echo "</table>";
  }
  echo "<div align='center'>共有".$pages."页(".$page."/".$pages.")";
  for ($i=1;$i< $page;$i++)
   echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
   echo "[".$page."]";
   for ($i=$page+1;$i<=$pages;$i++)
    echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
    echo "</div>";
   ?>
  </body>
  </html>

  5、总结

  本例代码在windows2000 server+php4.4.0+mysql5.0.16上运转正常。该示例显示的分页格局是…如许模式。假设想显示成“首页 上一页 下一页 尾页”如许模式,请到场以下代码:

$first=1;
$prev=$page-1;
$next=$page+1;
$last=$pages;

if ($page > 1)
{
 echo "<a href='fenye.php?page=".$first."'>首页</a> ";
 echo "<a href='fenye.php?page=".$prev."'>上一页</a> ";
}

if ($page < $pages)
{
 echo "<a href='fenye.php?page=".$next."'>下一页</a>
 echo "<a href='fenye.php?page=".$last."'>尾页</a> ";
}

  其实,写分页显示代码是很复杂的,只需把握了它的任务道理。但愿这篇文章可以带给那些需求这方面法式web法式员的匡助。理解网站这一概念之后不难看出,任何网站都是由网页组成的,也就是说想完成网站,必须先学会做网页,因此必须要掌握了HTML,才能为今后制作网站打下基础。

海妖 发表于 2015-2-4 13:15:08

当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,

灵魂腐蚀 发表于 2015-2-4 22:21:18

要进行开发,搭建环境是首先需要做的事,windows下面我习惯把环境那个安装在C盘下面,因为我配的环境经常出现诡异事件,什么事都没做环境有的时候就不能用啦。

若相依 发表于 2015-2-5 12:17:24

Ps:以上纯属原创,如有雷同,纯属巧合

小女巫 发表于 2015-2-25 11:03:03

其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎

飘灵儿 发表于 2015-3-7 19:59:39

本文当是我的笔记啦,遇到的问题随时填充

冷月葬花魂 发表于 2015-3-9 00:11:46

实践是检验自己会不会的真理。

山那边是海 发表于 2015-3-11 22:07:20

这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。

蒙在股里 发表于 2015-3-19 14:47:11

真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,

深爱那片海 发表于 2015-3-28 05:03:29

你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。

金色的骷髅 发表于 2015-4-6 13:04:28

当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,

小妖女 发表于 2015-5-8 08:01:26

Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81

兰色精灵 发表于 2015-6-6 22:26:59

做为1门年轻的语言,php一直很努力。

谁可相欹 发表于 2015-6-9 02:33:19

我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。

不帅 发表于 2015-6-16 20:49:39

我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。

乐观 发表于 2015-6-24 05:52:18

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

柔情似水 发表于 2015-6-24 06:54:09

建议加几个专业的phper的群,当然啦需要说话的人多,一处一点问题能有人回答你的,当然啦要让人回答你的问题,平时就得躲在里面聊天,大家混熟啦,愿意回答你问题的人自然就多啦。

爱飞 发表于 2015-6-24 21:20:00

不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。

再见西城 发表于 2015-6-25 22:22:54

如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域,
页: [1]
查看完整版本: PHP网站制作之web开辟中PHP+MySQL分页显示示例剖析