PHP无限循环获取MySQL中的数据实例代码
最近公司有个需求需要从MySQL获取数据,然后在页面上无线循环的翻页展示。主要就是一直点击一个按钮,然后数据从最开始循环到末尾,如果末尾的数据不够了,那么从数据的最开始取几条补充上来。
其实,这个功能可以通过JQ实现,也可以通过PHP+MYSQL实现,只不过JQ比较方便而且效率更高罢了。
每次显示10条数据。
publicfunctionget_data($limit){ $sql="select*from((selectid,namefrom`mytable`limit{$limit},10)unionall(selectid,namefrom`mytable`limit0,10))astestlimit0,10"; return$this->query($sql); }
上述sql语句通过mysql的unionall方法,把两个集合拼接到一起,并取前十条数据。
publicfunctiongetCount(){//获取数据的条数 $sql="selectcount(id)astfrom`mytable`"; return$this->query($sql); }
下一步在控制器中获取数据,并给ajax提供数据接口。
//测试数据库无限循环取数据 publicfunctiongetInfiniteData(){ //用户点击数 $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($dataas$key=>$v){ $list[$key]=$data[$key][0]; } $info['msg']=$list; $info['code']='001'; }else{ $info['code']='002'; $info['msg']='暂无数据'; } echojson_encode($info,JSON_UNESCAPED_UNICODE);die; }
总结
以上所述是小编给大家介绍的PHP无限循环获取MySQL中的数据实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!