PHP无限循环取MySQL中的数据。
2018-06-22 05:26:28来源:未知 阅读 ()
最近公司有个需求需要从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代码我就不贴了。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- PHP写UltraEdit插件脚本实现方法 2020-03-29
- php 带逗号千位符数字的处理方法 2020-03-28
- PHP三元运算符的结合性介绍 2020-03-28
- PHP静态延迟绑定和普通静态效率的对比 2020-03-28
- 基于php流程控制语句和循环控制语句 2020-03-28
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash