凹丫丫网络社区's Archiver

凹丫丫 发表于 2007-10-20 15:14

十天学会php之第8~10天

[font=Arial]学习目的:做一个分页显示[/font]


[font=Arial]  关键就是用到了SQL语句中的limit来限定显示的记录从几到几。我们需要一个记录当前页的变量$page,还需要总共的记录数$num[/font]

[font=Arial]  对于$page如果没有我们就让它=0,如果有<0就让它也=0,如果超过了总的页数就让他=总的页数。[/font]

[font=Arial]  $execc="select count(*) from tablename ";
  $resultc=mysql_query($execc);
  $rsc=mysql_fetch_array($resultc);
  $num=$rsc[0];[/font]

[font=Arial]  这样可以得到记录总数
  ceil($num/10))如果一页10记录的话,这个就是总的页数[/font]
[font=Arial]  所以可以这么写
  if(empty($_GET['page']))
  {
  $page=0;
  }
  else
  {
  $page=$_GET['page'];
  if($page<0)$page=0;
  if($page>=ceil($num/10))$page=ceil($num/10)-1;//因为page是从0开始的,所以要-1
  } [/font]
[font=Arial]  这样$exec可以这么写 $exec="select * from tablename limit ".($page*10).",10";
  //一页是10记录的[/font]

[font=Arial]  最后我们需要做的就是几个连接:
  <a href="xxx.php?page=0">FirstPage</a>
  <a href="xxx.php?page=<?=($page-1)?>">PrevPage</a>
  <a href="xxx.php?page=<?=($page+1)?>">NextPage</a>
  <a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a>[/font]

[font=Arial]  这是一个大致的思路,大家可以想想怎么来优化?今天说到这里,明天说一下一些注意的问题。[/font]

凹丫丫 发表于 2007-10-20 15:15

十天学会php之第8~10天

[font=Arial]学习目的:注意事项[/font]  
[font=Arial]  因为我是先学ASP的,所以再做PHP的时候会发现很多地方需要适应。[/font]

[font=Arial]  1、注意不要漏了分号
  2、注意不要漏了变量前的$
  3、使用SESSION的时候注意不要遗漏session_start();[/font]

[font=Arial]  如果发生错误的时候,可以采用以下方法:
  1、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句
  2、如果是变量为空,大多是没有传递到位,输出变量检查一下,检查一下表单的id和name
  3、如果是数据库连接出错,检查是否正确打开MY SQL和是否遗漏了连接语句
  4、注意缩进,排除括号不区配的错误[/font]

[font=Arial]  在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系。然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合。一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题。前台还需要注意安全性和容错还有就是输出格式。[/font]
[font=Arial]  好了,今天说到这里,明天说一下如果用PHP上传文件和发邮件。[/font]

凹丫丫 发表于 2007-10-20 15:15

十天学会php之第8~10天

[font=Arial]学习目的:学会用PHP上传文件和发邮件[/font]
[font=Arial]  上传文件表单必须加上 enctype="multipart/form-data" 和 <input type="file" name="file">
  
  下面看一下代码:[/font]

[font=Arial]  $f=&$HTTP_POST_FILES['file'];
  $dest_dir='uploads';//设定上传目录
  $dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我这里设置文件名为日期加上文件名避免重复
  $r=move_uploaded_file($f['tmp_name'],$dest);
  chmod($dest, 0755);//设定上传的文件的属性[/font]

[font=Arial]  上传的文件名为date("ymd")."_".$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录。move_uploaded_file($f['tmp_name'],$dest);这是关键[/font]

[font=Arial]  至于发邮件就更加简单,可以使用mail()函数mail("收件人地址","主题","正文","From:发件人\r\nReply-to:发件人的地址");[/font]
[font=Arial]  不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行。
  
  好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了。ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的。[/font]

[font=Arial]  十天学会PHP说到这里了,我的三大系列文章都用《十天学会》作为名字,想告诉大家的是ASP,PHP,ASP.NET入门都可以是十天,但是精通决不是十天啊,还需要大家自己去研究。[/font]

页: [1]

Powered by Discuz! Archiver 7.0.0  © 2001-2007 Comsenz Inc.