你好,游客 登录 注册 搜索
背景:
阅读新闻

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

[日期:2017-08-31] 来源:Linux社区  作者:lotus-white [字体: ]

  最近公司有个需求需要从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;

    }

JS代码我就不贴了。

本文永久更新链接地址http://www.linuxidc.com/Linux/2017-08/146625.htm

linux
相关资讯       PHP无限循环获取MySQL数据 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款