jonvi 发表于 2017-12-29 18:40:01

php实现搜索和分页效果

  php搜索+分页,单写容易,组合起来不容易,网上找了一下,代码不全,搜索和分页没有完全实现,经过自己的修改尝试,成功实现简单的搜索+分页功能。
  效果如下:

  下面是完整的代码!写在一个php页面里面即可!所需要做的修改就是你的数据库信息和表信息。即可实现上面图片同样的效果!感谢网上分享的网友,我在此基础上改出了自己想要的功能,因此也贴出来,想对有些朋友有帮助。
  <?php
  $wherelist=array();
  $urlist=array();
  if(!empty($_GET['id']))
  {

  $wherelist[]=">  $urllist[]="id=".$_GET['id'];
  }
  if(!empty($_GET['username']))
  {
  $wherelist[]=" username like '%".$_GET['username']."%'";
  $urllist[]="username=".$_GET['username'];
  }if(!empty($_GET['age']))
  {
  $wherelist[]=" age like '%".$_GET['age']."%'";
  $urllist[]="age=".$_GET['age'];
  }
  $where="";
  if(count($wherelist)>0)
  {
  $where=" where ".implode(' and ',$wherelist);
  $url='&'.implode('&',$urllist);
  }
  //分页的实现原理
  //1.获取数据表中总记录数
  $mysql_server_name='localhost';
  $mysql_username='root';
  $mysql_password='root';
  $conn=mysql_connect($mysql_server_name,$mysql_username,$mysql_password);
  mysql_query("set names 'utf8'");
  mysql_select_db("aaa");
  $sql="select * from user $where ";
  $result=mysql_query($sql);
  $totalnum=mysql_num_rows($result);
  //每页显示条数
  $pagesize=5;
  //总共有几页
  $maxpage=ceil($totalnum/$pagesize);
  $page=isset($_GET['page'])?$_GET['page']:1;
  if($page <1)
  {
  $page=1;
  }
  if($page>$maxpage)
  {
  $page=$maxpage;
  }
  $limit=" limit ".($page-1)*$pagesize.",$pagesize";

  $sql1="select * from user {$where} order by>  $res=mysql_query($sql1);
  ?>
  <!DOCTYPE html>
  <html>
  <head>
  <meta charset="UTF-8">
  <title>用户资料显示</title>
  </head>
  <body>
  <form action="searchpage.php" method="get">

  id:<input type="text" name="id" value="<?php echo $_GET['id']?>">
  用户名<input type="text" name="username" value="<?php echo $_GET['username']?>">
  年龄:<input type="text" name="age" value="<?php echo $_GET['age']?>">  <input type="button" value="查看全部">
  <input type="submit" value="搜索">
  </form>
  <br/>

  <table border="1">  <tr>
  <td>编号</td>
  <td>用户名</td>
  <td>年龄</td>
  <td>性别</td>
  <td>电话</td>
  <td>地址</td>
  </tr>
  <?php while($row= mysql_fetch_assoc($res)){?>
  <tr>
  <td><?php echo $row['id'] ?></td>
  <td><?php echo $row['username'] ?></td>
  <td><?php echo $row['age'] ?></td>
  <td><?php if($row['sex']){echo '男';}else{echo '女';} ?></td>
  <td><?php echo $row['phone'] ?></td>
  <td><?php echo $row['address'] ?></td>
  </tr>
  <?php }?>
  <tr>
  <td colspan="6">
  <?php
  echo " 当前{$page}/{$maxpage}页 共{$totalnum}条";
  echo " <a href='searchpage.php?page=1{$url}'>首页</a> ";
  echo "<a href='searchpage.php?page=".($page-1)."{$url}'>上一页</a>";
  echo "<a href='searchpage.php?page=".($page+1)."{$url}'>下一页</a>";
  echo " <a href='searchpage.php?page={$maxpage}{$url}'>尾页</a> ";
  ?>
  </td>
  </tr>
  </table>
  </body>
  </html>
页: [1]
查看完整版本: php实现搜索和分页效果