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

  系统标题:复杂检索数据并分页显示的处理方法

  系统功能:利用临时表检索数据库数据,然后分页显示的方法:

  处理方法:采用临时表存放数据中间结果,根据中间结果显示数据

  数据的显示采用隔行的方式处理

  处理优点:对于复杂的查询,特别是涉及到多表的数据查询,如果直接使用查询条件,系统的

  开销将很大,利用临时表把数据先保存,然后处理。这样对数据库的查询只要开销一次。

  使用方法:只要把连接数据库的用户信息和数据表改变即可使用

  <?

  //连接数据库

  $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