通过调用数据库得到的上一页下一页的id

jerry thinkphp 2015年11月19日 收藏
这个功能在文章页面中实现‘上一页’,‘下一页’导航链接时需要用到,但是文章的id一般是不连贯的,所以不能通过当前页id加一减一实现,而是查询数据库上下两行的记录的id来实现,现在写成函数如下
  1. <?php 
  2.     function article_guide($current_id,$table_name){//$current_id一般通过get得到
  3.         $A = M($table_name);//A = article
  4.         $result    = $A->order('id ASC')->select();
  5.         $guide['min_id']    = $link[0]['id'];                    //数据库中最小的id
  6.         $guide['max_id']    = $link[count($result)-1]['id'];    //数据库中最大的id
  7.         //得到上一篇文章的ID
  8.         $prev_id = $current_id-1;
  9.         while(($A->where('id="'.$prev_id.'"')->getField('id')) == false){
  10.             if($prev_id <= $min_id){
  11.                 $prev_id = '-1';//表示已经是最早的文章
  12.                 break ;
  13.             }
  14.             $prev_id--;
  15.         }
  16.         //得到下一篇文章的id
  17.         $next_id = $current_id+1;
  18.         while(($A->where('id="'.$next_id.'"')->getField('id')) == false){
  19.             if($next_id >= $max_id) {
  20.                 $next_id = '-2';//表示已经是最新的文章
  21.                 break;
  22.              }
  23.             $next_id++;
  24.         }
  25.         $guide['next_id'] = $next_id;
  26.         $guide['prev_id'] = $prev_id;
  27.         return $guide;
  28.     }
在你需要使用的操作中调用此函数,然后给模板赋值,给相应的上一页下一页链接添加相应的id即可。
还可以通过id判断页面是否可以访问:
  1. I('get.id') == -1 ? $this->error('没有更早的文章了!','index') : false;
  2. I('get.id') == -2 ? $this->error('没有更新的文章了!','index') : false;