php怎么实现两张不同的表分页
发表于:2024-10-14 作者:千家信息网编辑
千家信息网最后更新 2024年10月14日,这篇文章将为大家详细讲解有关php怎么实现两张不同的表分页,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php实现两张不同表分页的方法:1、创建一个PHP示例文件;
千家信息网最后更新 2024年10月14日php怎么实现两张不同的表分页
这篇文章将为大家详细讲解有关php怎么实现两张不同的表分页,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
php实现两张不同表分页的方法:1、创建一个PHP示例文件;2、通过"function getPage($a, $b, $page, $page_size){...}"实现跨表分页即可。
本文操作环境:windows7系统、PHP7.1版、DELL G3电脑
PHP 跨表分页
当两表数据相对均衡的情况下比较适用
$min_b || empty($b_f)) # b组数据小 重新查询a组 { # 查出偏移量 # 第二次查询 second $a_s = getRangeInfo($a, $min, $max_a); # second 第二次查找 # 求出新查出的数据与最开始查出a数组相差个数 $offset = count($a_s)-$a_f_len; } else { # a组数据小 重新查询b组 # 查出偏移量 $b_s = getRangeInfo($b, $min, $max_b); # 求出新查出的数据与最开始查出a数组相差个数 $offset = count($b_s)-$b_f_len; } } $now_position = $show = (int)($averge*2-$offset); $start_position = $page*$page_size; $end_position = ($page+1)*$page_size-1; // 假如一次查询某数组为空,查询的第二组数据未能涵盖所需全部数据,故重新查询 $a_s = getlimit($a, $min, $start_position-$now_position+$page_size); $b_s = getlimit($b, $min, $start_position-$now_position+$page_size); $total_arr = array_merge($a_s, $b_s) ; sort( $total_arr); # 升序排列 $res = []; foreach ($total_arr as $k=>$v) { if ($now_position > $end_position) { break; } if ($now_position < $start_position){ $now_position = $now_position+1; continue; } $now_position = $now_position+1; $res[] = $v; } // 思路如下: $min_str = $min_a > $min_b ? ' 最小数在b, 重新获取a数据'.json_encode($a_s):'最小数在a, 重新获取b数据'.json_encode($b_s); print_r('数组$a:'.json_encode($a)); echo '
'; print_r('数组$b:'.json_encode($b)); echo '
'; print_r('平均数floor is '.$averge.', $a 最小值是 '.$min_a.',$b 最小值是 '.$min_b.', 对比之后得出最小值是'.$min.','.$min_str. '此时偏移量'.$offset.', 最小数'.$min.'处于位置'.$show.', 我需要'.$start_position.'到'.$end_position.'的数据, 查出所需数据为'.json_encode($total_arr).', 结果为'.json_encode($res)); return $res;}// 按值范围获取function getRangeInfo ($array, $start_value, $end_value){ sort($array); $res = []; foreach ($array as $k => $v) { if ($v >= $start_value && $v <= $end_value){ $res[] = $v; } } return $res;}// 按起始位置个数获取function getlimit ($array, $start_value, $num){ sort($array); $res = []; foreach ($array as $k => $v) { if ($num<=0) { break; } if ($v >= $start_value){ $res[] = $v; $num --; } } return $res;}$b = [1];$a = [2,3,1,4,5,6,7,8,9,10,12,14];$page = 2; # 第一页$page_size = 5;$list = getPage($a, $b, $page, $page_size);$all = array_merge($a, $b);sort($all);echo '
';echo '
';echo '
';$start_position = $page*$page_size;$real = array_slice($all, $start_position, $page_size);print_r('合并总数据'.json_encode($all).',一页'.$page_size.'条, 第'.(string)($page+1).'页数据为:'.json_encode($real));
关于"php怎么实现两张不同的表分页"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
数据
最小
查询
数组
不同
篇文章
偏移
个数
更多
求出
不错
实用
均衡
位置
内容
升序
平均数
情况
文件
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
更改数据库日期的sql
sql数据库在公司的应用
深圳艾果互联网通讯科技
车载网络安全架构
网络技术 英语词典
endnote导入数据库
双梦服务器
服务器在国外的app能打开吗
足疗店服务器
数据库数据和操作日志
企业仓库管理系统数据库
联想服务器不识别光驱
瑞虎8酷我音乐服务器错误
网络安全哪个公司待遇好
中央电视中专计算机网络技术中专
网络安全设备设计方案
军队网络安全 检查
软件开发过程模型 定义
人人时代网络技术查
软件开发的大学专业好
计算机网络技术好吗
再发生危害网络安全的视频
数据库常见指令
阐述维护网络安全的重要意义
网络安全宣传题
辽宁优质软件开发
数据库不具备什么
北京国电通网络技术公司
郑州软件开发测试机构
服务器主板黑色硬盘接口