PHP无限循环取MySQL中的数据。

Posted 呼尔查•恩和

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP无限循环取MySQL中的数据。相关的知识,希望对你有一定的参考价值。

  最近公司有个需求需要从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 getCount(){//获取数据的条数
2         $sql="select count(id) as t from `mytable`";
3         return $this->query($sql);
4  }

  下一步在控制器中获取数据,并给ajax提供数据接口。

 1  //测试数据库无限循环取数据
 2      public function getInfiniteData(){
 3         //用户点击数
 4         $page = $_GET[‘click‘];
 5      //每次展示条数
 6         $pagesize = 10;
 7      //获取总条数
 8         $total = $this->Mydemo->get_count();
 9         $t = $total[0][0][‘t‘];
10      //算出每次点击的其起始位置
11         $limit = (($page - 1)*$pagesize)%$t;
12 
13         $data = $this->Mydemo->get_data($limit);
14 
15         if (!empty($data)) {
16             //转换为二维数组
17             $list = [];
18             foreach ($data as $key => $v) {
19                 $list[$key] = $data[$key][0];
20             }
21 
22             $info[‘msg‘] = $list;
23             $info[‘code‘] = ‘001‘;
24         }else{
25             $info[‘code‘] = ‘002‘;
26             $info[‘msg‘] = ‘暂无数据‘;
27         }
28         echo json_encode($info,JSON_UNESCAPED_UNICODE);die;
29 
30     }

 JS代码我就不贴了。

  

 

以上是关于PHP无限循环取MySQL中的数据。的主要内容,如果未能解决你的问题,请参考以下文章

使用 PHP 选择并显示 MySQL 表中的所有字段以获取无限量的列

无限循环 - 延迟 - 单独的线程

PHP 在循环中无限休眠

PHP二叉树递归遍历无限循环问题

使用 json rereiver php mysql 在片段中填充列表视图

sicily数据结构