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三种数据库实现分页查询的方法. 可能会有人说这些网上都有,但我的主要目的是把这些知识通过我实际的应 ...
随机推荐
- [ZOJ 1003] Crashing Balloon (dfs搜索)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=3 题目大意:给你a,b两个数,问当b由约数1到100组成时,a能否由其 ...
- php mysql 中文乱码解决方法
本文章向码农们介绍php mysql 中文乱码解决方法,对码农们非常实用,需要的码农可以参考一下. 从MySQL 4.1开始引入多语言的支持,但是用PHP插入的中文会出现乱码.无论用什么编码也不行 解 ...
- WIN7上搭建Windows Phone 8 开发环境——VMware Workstation下Win8 “无法安装Hyper-V, 某个虚拟机监控程序正在运行”问题解决的办法
最近在试着在Windows 7上搭建Windows Phone 8的开发调试环境,使用的是VMware Workstation + Win8 Pro的虚拟环境, 在漫长的WPexpress_full下 ...
- visual studio R6034解决方案集 从VC6.0 或VC2003 到VC2005发现的问题
这是我转的一篇非常全的帖子 能查到的解决方法都在里面有提及: 我是使用 stdafx.h加入这句 code #pragma comment(linker, "\"/manifest ...
- python基础set
1.set set是一个无序的不重复的集合 li=[11,22,33,11] s=set(li) print(s) {11,22,33} set提供的方法 1.add(self, *args, ** ...
- 也谈LBP
LBP(local banary patter)是一种非常经典的用来描述图像局部纹理特征的算子. 1,基本LBP LBP方法自1994年提出,此后就作为一个有效的纹理特征,不断的被人使用和改进.LBP ...
- android + javascript 相互通信实例分析
1. AndroidManifest.xml中必须使用许可 "android.permission.INTERNET", 否则会出Web page not available错误 ...
- IBM Tivoli NetView网管软件实战
广大网络管理者需要一款包括网络监控故障处理的一个集成网络管理平台,本文根据作者多年实践提出的基于IBM Tivoli Netview的综合网络管理平台,IBM Tivoli与Cisco一直保持着良好的 ...
- SOS 调试扩展 (SOS.dll) 《第五篇》
一.SOS扩展命令 SOS包含几十个命令,要熟练使用SOS,首先要了解SOS有哪些命令.下面给出SOS命令列表. 命令 描述 BPMD [<module name> <method ...
- ERS-2卫星
ERS-2卫星是欧洲空间局的第二颗资源遥感卫星,携带有雷达测高仪.综合孔径雷达等多种科学仪器,是一颗多任务.多学科的科学考察卫星.[1] ERS-1 ERS-2 欧空局分别于1991年和1995年发射 ...