zoukankan      html  css  js  c++  java
  • 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 get_count(){//获取数据的条数 
    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代码我就不贴了。

      

    4ever Love for my Girl
  • 相关阅读:
    系统优化怎么做-JVM优化之开篇
    系统优化怎么做-Tomcat优化
    系统优化怎么做-Linux系统配置优化
    系统优化怎么做-SQL优化
    系统优化怎么做-数据库优化
    系统优化怎么做-新系统上线前做什么
    系统优化怎么做-开篇
    一起学习Avalonia(一)
    etcd的应用举例
    c#总结几种正则表达式使用
  • 原文地址:https://www.cnblogs.com/lotus-white/p/7405197.html
Copyright © 2011-2022 走看看