阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

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

220次阅读
没有评论

共计 1217 个字符,预计需要花费 4 分钟才能阅读完成。

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

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1217字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中