php实现搜索和分页效果-亲测有效

Posted 暗号已存在

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php实现搜索和分页效果-亲测有效相关的知识,希望对你有一定的参考价值。

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

效果如下:

php实现搜索+分页

下面是完整的代码!写在一个php页面里面即可!所需要做的修改就是你的数据库信息和表信息。即可实现上面图片同样的效果!感谢网上分享的网友,我在此基础上改出了自己想要的功能,因此也贴出来,想对有些朋友有帮助。

<?php
$wherelist=array();
$urlist=array();
if(!empty($_GET[\'id\']))
{
$wherelist[]=" id like \'%".$_GET[\'id\']."%\'";
$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 id desc {$limit}"; //此处加了id降序
$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\']?>" size="8">
用户名<input type="text" name="username" value="<?php echo $_GET[\'username\']?>" size="8">
年龄:<input type="text" name="age" value="<?php echo $_GET[\'age\']?>" size="8">
 <input type="button" value="查看全部" onclick="window.location=\'searchpage.php\'">
 <input type="submit" value="搜索">
</form>
<br/>
<table border="1" width="500" >
 <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>

以上是关于php实现搜索和分页效果-亲测有效的主要内容,如果未能解决你的问题,请参考以下文章

TP3.2TP3.2下实现ajax分页(原创+亲测可用)

Mybatis Plus 多表关联分页查询(亲测有效)

php文件更新后不生效?亲测有效!

亲测有效!一种完美动态阈值白平衡算法 Java实现。

laravel下实现阿里云短信服务 (laravel-aliyun-sms)亲测有效

亲测有效iPhone实现定时关机开机 - 远离手机 准时睡觉