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


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 相关文章推荐
PHP 和 HTML
Oct 09 PHP
十天学会php之第八天
Oct 09 PHP
ajax实现无刷新分页(php)
Jul 18 PHP
PHP下打开phpMyAdmin出现403错误的问题解决方法
May 23 PHP
php使用glob函数快速查询指定目录文件的方法
Nov 15 PHP
php中ob_flush函数和flush函数用法分析
Mar 18 PHP
php获取远程文件内容的函数
Nov 02 PHP
变量在 PHP7 内部的实现(二)
Dec 21 PHP
php自定义函数实现二维数组排序功能
Jul 20 PHP
PHP4和PHP5版本下解析XML文档的操作方法实例分析
May 20 PHP
thinkphp5.1框架模板赋值与变量输出示例
May 25 PHP
open_basedir restriction in effect. 原因与解决方法
Mar 14 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
体育彩票排列三组选三算法分享
2014/03/07 PHP
PHP使用数组依次替换字符串中匹配项
2016/01/08 PHP
Yii2针对游客、用户防范规则和限制的解决方法分析
2016/10/08 PHP
PHP中类型转换 ,常量,系统常量,魔术常量的详解
2017/10/26 PHP
tp5框架使用cookie加密算法实现登录功能示例
2020/02/10 PHP
JavaScript RegExp方法获取地址栏参数(面向对象)
2009/03/10 Javascript
Mootools 1.2教程 选项卡效果(Tabs)
2009/09/15 Javascript
PHP+jQuery+Ajax实现多图片上传效果
2015/03/14 Javascript
JS获取iframe中marginHeight和marginWidth属性的方法
2015/04/01 Javascript
NodeJs中的VM模块详解
2015/05/06 NodeJs
第八篇Bootstrap下拉菜单实例代码
2016/06/21 Javascript
node+express制作爬虫教程
2016/11/11 Javascript
jquery——九宫格大转盘抽奖实例
2017/01/16 Javascript
$.browser.msie 为空或不是对象问题的多种解决方法
2017/03/19 Javascript
基于vue+ bootstrap实现图片上传图片展示功能
2017/05/17 Javascript
layui select获取自定义属性方法
2018/08/15 Javascript
node微信开发之获取access_token+自定义菜单
2019/03/17 Javascript
微信公众号生成新浪短网址的实现(快速生成)
2019/08/18 Javascript
vue-video-player 断点续播的实现
2021/02/01 Vue.js
[00:59]DOTA2背景故事第二期之四大基本法则
2020/07/07 DOTA
详解Python中映射类型(字典)操作符的概念和使用
2015/08/19 Python
python3实现点餐系统
2019/01/24 Python
openCV提取图像中的矩形区域
2020/07/21 Python
新加坡领先的时尚生活方式零售品牌:CHARLES & KEITH
2018/01/16 全球购物
AutoShack.com加拿大:北美主要的汽车零部件零售商
2019/07/24 全球购物
德国排名第一的主题公园门票网站:Attraction Tickets Direct
2019/09/09 全球购物
MAC彩妆澳洲官网:M·A·C AU
2021/01/17 全球购物
财政专业求职信范文
2014/02/19 职场文书
3.15国际消费者权益日主题活动活动总结
2014/03/16 职场文书
借款担保书范文
2014/05/13 职场文书
社区维稳工作方案
2014/06/06 职场文书
共产党员批评与自我批评
2014/10/15 职场文书
Pandas加速代码之避免使用for循环
2021/05/30 Python
这样写python注释让代码更加的优雅
2021/06/02 Python
RPM包方式安装Oracle21c的方法详解
2021/08/23 Oracle
MYSQL事务的隔离级别与MVCC
2022/05/25 MySQL