最近公司有个需求需要从MySQL获取数据,然后在页面上无线循环的翻页展示。主要就是一直点击一个按钮,然后数据从最开始循环到末尾,如果末尾的数据不够了,那么从数据的最开始取几条补充上来。 其实,这个功能可以通过JQ实现,也可以通过PHP + MYSQL实现,只不过JQ比较方便而且效率更高罢了。 每次显示10条数据。
public function/【php教程_linux常用命令_网络运维技术】/ get_data($limit){
$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";
return $this->query($sql);
}
上述sql语句通过mysql的union all方法,把两个集合拼接到一起,并取前十条数据。
public function getCount(){//获取数据的条数
$sql="select count(id) as t from mytable
";
return $this->query($sql);
}
下一步在控制器中获取数据,并给ajax提供数据接口。
//测试数据库无限循环取数据 public function getInfiniteData(){ //用户点击数 $page = $_GET['click']; //每次展示条数 $pagesize = 10; //获取总条数 $total = $this->Mydemo->get_count(); $t = $total0['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]/【本文中一些PHP版本可能是以前的,如果不是一定要,建议PHP尽量使用7.2以上的版本】/[0]; } $info['msg'] = $list; $info['code'] = '001'; }else{ $info['code'] = '002'; $info['msg'] = '暂无数据'; } echo json_encode($info,JSON_UNESCAPED_UNICODE);die; }
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。