最近公司有个需求需要从MySQL获取数据,然后在页面上无线循环的翻页展示。主要就是一直点击一个按钮,然后数据从最开始循环到末尾,如果末尾的数据不够了,那么从数据的最开始取几条补充上来。
其实,这个功能可以通过JQ实现,也可以通过PHP + MYSQL实现,只不过JQ比较方便而且效率更高罢了。
每次显示10条数据。
?
1
2
3
4
|
public function 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方法,把两个集合拼接到一起,并取前十条数据。
?
1
2
3
4
|
public function getCount(){ //获取数据的条数
$sql = "select count(id) as t from `mytable`" ;
return $this ->query( $sql );
}
|
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
//测试数据库无限循环取数据
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 ;
}
|
总结
以上所述是小编给大家介绍的PHP无限循环获取MySQL中的数据实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对快网idc网站的支持!
原文链接:http://www.cnblogs.com/lotus-white/archive/2017/08/21/7405197.html
相关文章
猜你喜欢
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
centos7使用docker部署gitlab-ce-zh应用详解
2025-05-25 57 -
2025-06-04 14
-
2025-05-25 72
-
2025-05-29 72
-
2025-05-27 53
热门评论