欢迎加入QQ讨论群258996829
麦子学院 头像
苹果6袋
6
麦子学院

PHP实现无限循环获取MySQL中的数据

发布时间:2017-09-03 23:31  回复:0  查看:2249   最后回复:2017-09-03 23:31  


本文和大家分享的主要是php实现无限循环获取MySQL中的数据相关内容,一起来看看吧,希望对大家 学习php有所帮助。
  最近有个需求需要从MySQL获取数据,然后在页面上无线循环的翻页展示。主要就是一直点击一个按钮,然后数据从最开始循环到末尾,如果末尾的数据不够了,那么从数据的最开始取几条补充上来。
  其实,这个功能可以通过JS+PHP实现,也可以通过PHP + MYSQL+JS实现,只不过JS+PHP比较方便而且效率更高罢了。
  下面是PHP + MYSQL+JS实现办法。
  每次显示10条数据。
  1 public function get_data($limit){2       $sql="select * from ((select id,name from `mytable` limit {$limit},10) union all (select id,name from `mytable` limit 0,10)) as test limit 0,10";3
     return $this->query($sql);4 }
  上述sql语句通过mysql的union all方法,把两个集合拼接到一起,并取前十条数据。
  1  public function get_count(){//获取数据的条数 2
  $sql="select count(id) as t from `mytable`"; 3
  return $this->query($sql); 4 }
  下一步在控制器中获取数据,并给ajax提供数据接口。
  //测试数据库无限循环取数据
  public function getInfiniteData(){
  //用户点击数
  $page = $_GET['click'];
  //每次展示条数
  $pagesize = 10;
  //获取总条数
  $total = $this->Mydemo->get_count();
  $t = $total[0][0]['t'];
  //算出每次点击的其起始位置
  $limit = (($page - 1)*$pagesize)%$t;
  $data = $this->Mydemo->get_data($limit);
  if (!empty($data)) {
  //转换为二维数组
  $list = [];
  foreach ($data as $key => $v) {
  $list[$key] = $data[$key][0];
  }
  $info['msg'] = $list;
  $info['code'] = '001';
  }else{
  $info['code'] = '002';
  $info['msg'] = '暂无数据';
  }
  echo json_encode($info,JSON_UNESCAPED_UNICODE);die;
  }


来源:Linux公社

您还未登录,请先登录

热门帖子

最新帖子