复杂检索数据并分页显示的处理方法


Posted in PHP onOctober 09, 2006

系统标题:复杂检索数据并分页显示的处理方法
系统功能:利用临时表检索数据库数据,然后分页显示的方法:
处理方法:采用临时表存放数据中间结果,根据中间结果显示数据
          数据的显示采用隔行的方式处理
处理优点:对于复杂的查询,特别是涉及到多表的数据查询,如果直接使用查询条件,系统的
          开销将很大,利用临时表把数据先保存,然后处理。这样对数据库的查询只要开销一次。
使用方法:只要把连接数据库的用户信息和数据表改变即可使用

<?
  //连接数据库
  $dbh =  mysql_connect('localhost:3306','root','');
  mysql_select_db('test');  

  //把数据检索的结果保存到临时表中
   $ls_sql  = ' create temporary table temps ';
   $ls_sql .= ' select lk_title,lk_link from  lk_t_content ';
   $ls_sql .= " where lk_title like '%".$searchcontent."%' ";
   $res = mysql_query($ls_sql, $dbh);

  //得到检索数据的总数   
   $ls_sql = 'select count(*) as rcnt_con from temps ';
   $res = mysql_query($ls_sql, $dbh);
   $rcon = $row["rcnt_con"];   

   $pages=ceil($rcon / 20); //$pages变量现在总的页数   
   if (empty($offset))  {
       $offset=1;   
       $curline = 0;
    } else
      $curline = ($offset - 1) * 20;
   //打印表头
   print '<table width="100%" border="0">';
   print '<tr class="text"> <td width="50%">  <div align="center">';
   if ($offset <> 1) { //如果偏移量是0,不显示前一页的链接   
     $newoffset=$offset - 1;   
     print "<a href='$PHP_SELF?offset=$newoffset'>前一页</a>";   
   }  else {
     print "前一页";
     print "   ";
   }
  //显示所有的页数   
  for ($i=1; $i <= $pages; $i++)  {
    $temps = "<a href='".$PHP_SELF.'?offset='.$i."'>".$i."</a>";
    print $temps;   
    print "   ";
  }   
  //检查是否是最后一页   
  if ($pages!=0 && $offset!=$pages)  {
     $newoffset=$offset+1;   
     print "<a href='$PHP_SELF?offset=$newoffset'>下一页</a>";   
  }  else print "下一页";
  print '</div> </td>';
  print '<td width="50%">  <div align="center">';
  print "当前页:".$offset." 共".$pages."页";
  print '</div> </td>';
  print "</table>";

  //显示查询信息
  print '<table width="100%" border="1">';
  print '<tr class="text"> ';
  print '<td width="100%">  <div align="center">查询结果信息</div> </td>';
  print '</tr>';

  $query = "select lk_title,lk_link from temps order by lk_title desc LIMIT ".$curline.",20";
  $res = mysql_query($query, $dbh);  

  $li_num = 0;
  while ($row = mysql_fetch_array($res)) {  
     //采用隔行显示的方法显示信息内容
     if ($li_number == 0) {
        <tr bgcolor="#dedede">
    $li_number = 1;
     } else {
        <tr bgcolor="#ededed">
    $li_number = 0;
     }
     $tempstr = "<a href='".$row[lk_link]."'>".$row['lk_title']."</a>";
     print '<td width="100%" height="15" class="text"> '.$tempstr.'</td>';
     print '</tr>';
  }
  print "</table>";
?>
----------------------------
欢迎访问:zhangcg.oso.com.cn 

PHP 相关文章推荐
截获网站title标签之家内容的例子
Oct 09 PHP
PHP一些常用的正则表达式字符的一些转换
Jul 29 PHP
php实现utf-8和GB2312编码相互转换函数代码
Feb 07 PHP
PHP CLI模式下的多进程应用分析
Jun 03 PHP
输入值/表单提交参数过滤有效防止sql注入的方法
Dec 25 PHP
详解PHP导入导出CSV文件
Nov 03 PHP
详解WordPress开发中的get_post与get_posts函数使用
Jan 04 PHP
详谈php中 strtr 和 str_replace 的效率问题
May 14 PHP
使用PHP+MySql实现微信投票功能实例代码
Sep 29 PHP
PHP正则判断一个变量是否为正整数的方法
Feb 27 PHP
php curl操作API接口类完整示例
May 21 PHP
Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示例
Oct 12 PHP
PHP脚本的10个技巧(5)
Oct 09 #PHP
打造计数器DIY三步曲(中)
Oct 09 #PHP
打造计数器DIY三步曲(下)
Oct 09 #PHP
打造计数器DIY三步曲(上)
Oct 09 #PHP
PHP脚本的10个技巧(4)
Oct 09 #PHP
聊天室php&amp;mysql(六)
Oct 09 #PHP
PHP脚本的10个技巧(3)
Oct 09 #PHP
You might like
PHP iconv 函数转gb2312的bug解决方法
2009/10/11 PHP
php压缩和解压缩字符串的方法
2015/03/14 PHP
js cookies 常见网页木马挂马代码 24小时只加载一次
2009/04/13 Javascript
编写高性能的JavaScript 脚本的加载与执行
2010/04/19 Javascript
bgsound 背景音乐 的一些常用方法及特殊用法小结
2010/05/11 Javascript
一个报数游戏js版(约瑟夫环问题)
2010/08/05 Javascript
js中一个函数获取另一个函数返回值问题探讨
2013/11/21 Javascript
JavaScript字符串常用类使用方法汇总
2015/04/14 Javascript
window.location.hash知识汇总
2015/11/09 Javascript
对Js OOP编程 创建对象的一些全面理解
2016/07/26 Javascript
基于jQuery实现淡入淡出效果轮播图
2020/07/31 Javascript
购物车前端开发(jQuery和bootstrap3)
2016/08/27 Javascript
Nodejs进阶:基于express+multer的文件上传实例
2016/11/21 NodeJs
详解Python中logging日志模块在多进程环境下的使用
2016/12/26 Javascript
vue2 如何实现div contenteditable=“true”(类似于v-model)的效果
2017/02/08 Javascript
ES6中Array.find()和findIndex()函数的用法详解
2017/09/16 Javascript
angular4中*ngFor不能对返回来的对象进行循环的解决方法
2018/09/12 Javascript
js使用swiper实现层叠轮播效果实例代码
2018/12/12 Javascript
JavaScript中的一些实用小技巧总结
2019/04/07 Javascript
详解在React-Native中持久化redux数据
2019/05/22 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
2020/08/05 Javascript
Python中字符串的修改及传参详解
2016/11/30 Python
Python简单实现查找一个字符串中最长不重复子串的方法
2018/03/26 Python
Pandas 对Dataframe结构排序的实现方法
2018/04/10 Python
NumPy 数学函数及代数运算的实现代码
2018/07/18 Python
python实现对任意大小图片均匀切割的示例
2018/12/05 Python
详解python列表生成式和列表生成式器区别
2019/03/27 Python
python实现定时压缩指定文件夹发送邮件
2020/12/22 Python
Python数据库小程序源代码
2019/09/15 Python
python内置模块collections知识点总结
2019/12/19 Python
python 负数取模运算实例
2020/06/03 Python
加拿大便宜的隐形眼镜商店:Clearly
2016/09/15 全球购物
Huda Beauty官方商店:化妆和美容产品
2020/09/05 全球购物
拉拉队口号
2014/06/16 职场文书
网络营销计划
2015/01/17 职场文书
2015年度个人思想工作总结
2015/04/08 职场文书