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

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

<?
  //连接数据库
  $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截取汉字乱码问题解决方法mb_substr函数的应用
php heredoc和phpwind的模板技术使用方法小结
Mysql的GROUP_CONCAT()函数使用方法
php中变量及部分适用方法
php Undefined index和Undefined variable的解决方法
Mysql和网页显示乱码解决方法集锦
php中用文本文件做数据库的实现方法
PHP连接access数据库
php实现mysql数据库备份类
asp和php下textarea提交大量数据发生丢失的解决方法
支持php4、php5的mysql数据库操作类
PHP编程中字符串处理的5个技巧小结
一个图形显示IP的PHP程序代码
利用static实现表格的颜色隔行显示的代码
Discuz5.5.0代码高亮显示+运行代码框合成插件 下载第1/4页
PHP 中的批处理的实现
用PHP实现的随机广告显示代码
给apache2.2加上mod_encoding模块後 php5.2.0 处理url出现bug
PHP 中英文混合排版中处理字符串常用的函数
PHP中的日期处理方法集锦
PHP脚本的10个技巧(6)
PHP脚本的10个技巧(5)
如何在PHP中使用Oracle数据库(6)
如何在PHP中使用Oracle数据库(5)
如何在PHP中使用Oracle数据库(4)
人大复印资料处理程序_补充篇
如何在PHP中使用Oracle数据库(3)
人大复印资料处理程序_输入篇
人大复印资料处理程序_查询篇
如何在PHP中使用Oracle数据库(1)
Php+SqlServer实现分页显示
写一个用户在线显示的程序
PHP调用三种数据库的方法(3)
PHP调用三种数据库的方法(2)
PHP调用三种数据库的方法(1)
实现分十页分向前十页向后十页的处理
随机广告显示(PHP函数)
用文本作数据处理
使用无限生命期Session的方法
图象函数中的中文显示
桌面中心(四)数据显示
网站加速 PHP 缓冲的免费实现方法
©2014-2024 dbsqp.com