PHP搜索MYSQL数据库加分页浏览小结
PHP搜索加分页浏览小结:
1 分页后再做搜索
2 这里对于url的拼接,以及模糊查询,搜索时候的显示添加,SQL语句的拼接
3 对于页面传递过来的超级链接的变量,如果不存在就要设置,对于可能抛出异常的要加上@屏蔽错误
4 对于查询一般用一些关键字来获取
5 分页显示的limit条件要写好
6 搜索时候的where条件 搜索表单:
<!--- 搜索表单--->
<form action="list3.php" method="get">
标题:<input type="text" name="title" size="10" value="<?php echo @$_GET['title'];?>"/>
关键字:<input type="text" name="keywords" size="10" value="<?php echo @$_GET['keywords'];?>"/>
作者:<input type="text" name="author" size="10" value="<?php echo @$_GET['author'];?>"/>
<input type="submit" value="搜索"/>
<input type="button" value="全部信息" onclick="window.location='list3.php'"/>
</form>
<!----------------> 分页封装
<?php
//=======================
//封装搜索的信息
//定义一个封装搜索条件的数组变量
$wherelist=array();
//定义一个封装搜索的url,用于放置到url后面作为参数
$urllist=array();
//判断新闻标题是否有值就封装搜索条件
if(!empty($_GET['title'])){
$wherelist[]="title like '%{$_GET['title']}%'";
$urllist[]="title={$_GET['title']}"; }
//判断关键字是否有值就封装搜索条件
if(!empty($_GET['keywords'])){
$wherelist[]="keywords like '%{$_GET['keywords']}%'";
$urllist[]="keywords={$_GET['keywords']}";
}
//判断作者是否有值就封装搜索条件
if(!empty($_GET['author'])){
$wherelist[]="author like '%{$_GET['author']}%'";
$urllist[]="author={$_GET['author']}";
}
//组装搜索条件
//将数组合并成字符串用implode();
if(count($wherelist)>0){
$where=" where ".implode(" and ",$wherelist);
$url=@"&".implode("&",$urllist);
}
//echo @$where;
//echo @$url; //=======================
?> 3 分页处理
<?php
//=====插入分页处理代码=====
//1 定义分页的变量
$page=isset($_GET['page'])?$_GET['page']:1;//当前页数,默认为1
$pageSize=4; //页大小
$maxRows=""; //最大数据条数
$maxPages=""; //最大页数 //获取最大数据条数
@$sql="select count(*) from news {$where}";
$res=mysql_query($sql,$conn);
$maxRows=mysql_result($res,0,0);//定位从结果集中获取总数据的条数,就是获取第一个单元格中的值 //3 计算出最大页数
$maxPages=ceil($maxRows/$pageSize);//进一取整获取最大页数,7/3;
//4 判断页数是否越界,判断是否有效
if($page>$maxPages){
$page=$maxPages;
//判断是否超出了最大页
}
if($page<1){
$page=1;
}
//拼接$sql,限制每页显示的条数
$limit=" limit ".(($page-1)*$pageSize).",{$pageSize}";
//起始位置是当前页减1乘以每页显示的条数
//==========分页封装结束==============
@$sql="select * from news {$where} order by addtime desc {$limit}";
//limit 0,3表示从第一条记录到第三条记录
//将最新的新闻先显示出来
$result=@mysql_query($sql,$conn);?> 具体实例:新闻搜索和分页程序:
搜索和分页功能如下: list3.php 完整代码
<?php
header("content-Type:text/html;charset=utf-8");
?>
<?php
require("menu.php");
require("dbconfig.php");
?>
<title>新闻信息管理系统</title>
<script>
function dodel(id){
//判断是否要删除
if(confirm("确定要删除吗?")){
window.location="action.php?action=del&id="+id;
} } </script>
<center>
<h2>搜索和分页浏览新闻</h2>
<!--- 搜索表单--->
<form action="list3.php" method="get">
标题:<input type="text" name="title" size="10" value="<?php echo @$_GET['title'];?>"/>
关键字:<input type="text" name="keywords" size="10" value="<?php echo @$_GET['keywords'];?>"/>
作者:<input type="text" name="author" size="10" value="<?php echo @$_GET['author'];?>"/>
<input type="submit" value="搜索"/>
<input type="button" value="全部信息" onclick="window.location='list3.php'"/>
</form>
<!---------------->
<table border="1" cellpadding="2" cellspacing="0">
<tr><th>新闻id号</th><th>新闻标题</th><th>发布者</th>
<th>关键字</th><th>添加时间</th><th>新闻内容</th><th>操作</th>
</tr>
<?php
//=======================
//封装搜索的信息
//定义一个封装搜索条件的数组变量
$wherelist=array();
//定义一个封装搜索的url,用于放置到url后面作为参数
$urllist=array();
//判断新闻标题是否有值就封装搜索条件
if(!empty($_GET['title'])){
$wherelist[]="title like '%{$_GET['title']}%'";
$urllist[]="title={$_GET['title']}"; }
//判断关键字是否有值就封装搜索条件
if(!empty($_GET['keywords'])){
$wherelist[]="keywords like '%{$_GET['keywords']}%'";
$urllist[]="keywords={$_GET['keywords']}";
}
//判断作者是否有值就封装搜索条件
if(!empty($_GET['author'])){
$wherelist[]="author like '%{$_GET['author']}%'";
$urllist[]="author={$_GET['author']}";
}
//组装搜索条件
//将数组合并成字符串用implode();
if(count($wherelist)>0){
$where=" where ".implode(" and ",$wherelist);
$url=@"&".implode("&",$urllist);
}
//echo @$where;
//echo @$url; //=======================
?>
<?php
//=====插入分页处理代码=====
//1 定义分页的变量
$page=isset($_GET['page'])?$_GET['page']:1;//当前页数,默认为1
$pageSize=4; //页大小
$maxRows=""; //最大数据条数
$maxPages=""; //最大页数 //获取最大数据条数
@$sql="select count(*) from news {$where}";
$res=mysql_query($sql,$conn);
$maxRows=mysql_result($res,0,0);//定位从结果集中获取总数据的条数,就是获取第一个单元格中的值 //3 计算出最大页数
$maxPages=ceil($maxRows/$pageSize);//进一取整获取最大页数,7/3;
//4 判断页数是否越界,判断是否有效
if($page>$maxPages){
$page=$maxPages;
//判断是否超出了最大页
}
if($page<1){
$page=1;
}
//拼接$sql,限制每页显示的条数
$limit=" limit ".(($page-1)*$pageSize).",{$pageSize}";
//起始位置是当前页减1乘以每页显示的条数
//==========分页封装结束==============
@$sql="select * from news {$where} order by addtime desc {$limit}";
//limit 0,3表示从第一条记录到第三条记录
//将最新的新闻先显示出来
$result=@mysql_query($sql,$conn);
while($row=@mysql_fetch_assoc($result)){
echo "<tr>";
echo "<td>{$row['id']}</td>";
echo "<td>{$row['title']}</td>";
echo "<td>{$row['author']}</td>";
echo "<td>{$row['keywords']}</td>";
echo "<td>".date("Y-m-d H:i:s",$row['addtime'])."</td>";
echo "<td>{$row['content']}</td>";
echo "<td><a href='javascript:dodel({$row['id']})'>删除</a> | <a href='edit.php?id={$row['id']}'>修改 </a></td>";
echo "</tr>"; }
//释放结果集
@mysql_free_result($result);
mysql_close($conn);
?>
</table>
<?php
//显示当前页数值,上一页和下一页
echo "<br/>";
echo "当前页 {$page}/{$maxPages}页 共计:{$maxRows}条 ";?>
<a href="list3.php?page=1<?php echo @$url;?>">首页</a>
<a href="list3.php?page=<?php echo ($page-1).@$url;?>">上一页</a>
<!--这里用分割符号分离出来添加页数--->
<a href="list3.php?page=<?php echo ($page+1).@$url;?>">下一页</a>
<a href="list3.php?page=<?php echo $maxPages.@$url;?>">尾页</a> </center>
PHP搜索MYSQL数据库加分页浏览小结的更多相关文章
- 分页查询信息(使用jdbc连接mysql数据库实现分页查询任务)
分页查询信息 使用jdbc连接mysql数据库实现分页查询任务 通过mysql数据库提供的分页机制,实现商品信息的分页查询功能,将查询到的信息显示到jsp页面上. 本项目 ...
- lucene索引并搜索mysql数据库[转]
由于对lucene比较感兴趣,本人在网上找了点资料,终于成功地用lucene对mysql数据库进行索引创建并成功搜索,先总结如下: 首先介绍一个jdbc工具类,用于得到Connection对象: im ...
- MySQL数据库实现分页查询的SQL语句写法!
一:分页需求: 客户端通过传递start(页码),limit(每页显示的条数)两个参数去分页查询数据库表中的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的 ...
- PHP+mysql数据库简单分页实例-sql分页
前几天冷月写了一篇博文<php基础编程-php连接mysql数据库-mysqli的简单使用>,很多小伙伴在学习后都知道了php与mysql数据库的连接,今天冷月分享一个简单的分页实例 首先 ...
- PDO连接mysql数据库加载慢
今天在使用PDO连接mysql操作数据库的时候,发现速度特别慢,都1~2s的时间,不知道怎么回事,后来一步一步排除到new PDO 导致过慢的原因, 这个尴尬了...,调试了半天都没想到问下度娘,才知 ...
- mysql数据库limit分页,排序操作
看到网上很多朋友在问,limit分页之后按照字段属性排序的问题,在这里分享一下我的用法: 1.网上答案: 每页显示5个,显示第三页信息,按照年龄从小到大排序 select * from student ...
- PreparedStatement 基于mysql数据库做分页查询和统计查询
分页查询: 统计查询:
- oracle,mysql,SqlServer三种数据库的分页查询的实例。
MySql: MySQL数据库实现分页比较简单,提供了 LIMIT函数.一般只需要直接写到sql语句后面就行了.LIMIT子 句可以用来限制由SELECT语句返回过来的数据数量,它有一个或两个参数,如 ...
- MySQL、SQLServer2000(及SQLServer2005)和ORCALE三种数据库实现分页查询的方法
在这里主要讲解一下MySQL.SQLServer2000(及SQLServer2005)和ORCALE三种数据库实现分页查询的方法. 可能会有人说这些网上都有,但我的主要目的是把这些知识通过我实际的应 ...
随机推荐
- php mysql_select_db实例
在php中,我们经常需要连接数据库和操作数据库, 在操作数据库之前,我们需要选择一个数据库,本文章通过实例向小伙伴们介绍php mysql_select_db选择数据库的使用方法. 首先介绍一下mys ...
- Flash视频播放器开发经验总结
HTTP协议更优 目前几乎所有的视频点播网站全部采用HTTP协议传输数据.因为相对于诸如RTMP等协议来说,HTTP协议是无状态的,数据传输完毕就断开连接,这样服务器就可以腾出资源来服务更多的用户.而 ...
- random类的使用
小栗子a如下: string[] punch = new[] { "石头", "剪刀", "布" }; string myPunch; pu ...
- IBM Tivoli NetView网管软件实战
广大网络管理者需要一款包括网络监控故障处理的一个集成网络管理平台,本文根据作者多年实践提出的基于IBM Tivoli Netview的综合网络管理平台,IBM Tivoli与Cisco一直保持着良好的 ...
- Freebsd下压缩解压文件详解
压缩篇: 把/usr/webgames目录下的文件打包.命名为bak.tar.gz 放到/usr/db-bak目录里 下面命令可以在任意目录执行.无视当前目录和将要存放文件的目录.tar -zcvf ...
- mount挂载
与ln -s 功能类似 # mount --bind /data/public /home/user/public /etc/fstab # <file system> <mount ...
- Arch Linux 安装记录
Arch Linux 安装记录 基本上参考wiki上的新手指南,使用arch 2014.6.1 iso安装 设置网络 有线网络 Arch Linux 默认开启DHCP. 静态ip 首先关闭DHCP:s ...
- setjmp 与 longjmp
setjmp和longjmp是C语言独有的,只有将它们结合起来使用,才能达到程序控制流有效转移的目的,按照程序员的预先设计的意图,去实现对程序中可能出现的异常进行集中处理. 先来看一下这两个函数的定义 ...
- Magento修改css样式更新之——grunt命令使用
1.清除pub/static和var中相应文件 2.源头文件重新导入pub/static 3.pub中的less编译 4.字面翻译是跟踪源头文件变化实时编译,但是这里的the source files ...
- Android IOS WebRTC 音视频开发总结(六五)-- 给韩国电信巨头做咨询
本文主要总结咨询过程中的一些问题,文章最早发表在我们的微信公众号上,详见这里,欢迎关注微信公众号blackerteam 韩国电信巨头sk想了解国内移动互联网rtc现状,所以上周请我过去给他们的相关人员 ...