搜索
首页后端开发php教程查出当前id所在的页面

字段id:   数值  1~27
分页时:每页显示 8数据
已知一个id,求这个id所在的页数

我的思路:

$arr=array();for(int i=0;i<maxpage;i++){$sql=(select id from table limit i*8,(i+1)*8);  $arr[$i]+=$this->db->getAll($sql);}$arr={[0]=>(1~8)[1]=>(9~16)[2]=>(17~24)[3]=>(25~27)}让id 与数组$arr的value 比较 ,相同的话 获取出 key后+1就是它所在的页面




回复讨论(解决方案)

假定 id 连续,按 id 升序生成页面,则
$页号 = ceil($id / 8);

假定 id 连续,按 id 升序生成页面,则
$页号 = ceil($id / 8);


id不连续,用户有可能删除数据或被where过滤
有没有其它做法

不连续?那就需要知道 id 的分布情况

不连续?那就需要知道 id 的分布情况


id 的分布情况?
id就是不连续的

或者把数据库所有id都查出来,比较value,获取key,则  ceil((key+1)/8) 就是它所在的页数
如果数据多的多的话又很慢

已知一个id,求这个id在不连续id中正序的所在页数和位置(假设每页分X个)
eg
1: 已知id=5   id{1,2,5,9,10},  X=2   那么 已知id在第二页的第一个位置
2: 已知id=9   id{1,2,3,7,9,10}  X=2  那么  已知id在第三页的第一个位置

这种只能是把所有的id取出来,
然后按 顺序编号,

然后得到指定id的编号,
$页号 = ceil( $编号 / 8);

有了 id 的分布,那就好计算了

//已知id=5   id{1,2,5,9,10},  X=2   那么 已知id在第二页的第一个位置$id = 5;$a = array(1,2,5,9,10);$x = 2;$p = array_search($id, $a);echo ceil($p / $x) + 1; //2//已知id=9   id{1,2,3,7,9,10}  X=2  那么  已知id在第三页的第一个位置$id = 9;$a = array(1,2,5,9,10);$x = 2;$p = array_search($id, $a);echo ceil($p / $x) + 1; //3
如果 id 是乱序的,一样也可计算
$id = 9;$a = array(1,5,9,2,10);$x = 2;$p = array_search($id, $a);echo ceil($p / $x) + 1; //2

这种只能是把所有的id取出来,
然后按 顺序编号,

然后得到指定id的编号,
$页号 = ceil( $编号 / 8);



数据多的话,这种方法不好

或者 我求出最大页 第一页~最大页 获取第一个id  让已知id和第一个id进行比较  求出页数


这种只能是把所有的id取出来,
然后按 顺序编号,

然后得到指定id的编号,
$页号 = ceil( $编号 / 8);



数据多的话,这种方法不好

或者 我求出最大页 第一页~最大页 获取第一个id  让已知id和第一个id进行比较  求出页数

关键是你的需求,id是不连续的,你怎么知道每一页的第一个id是多少?
一样必须进行顺序编号,
不过简单一点,就是只 select 出0~指定id,就ok了



关于id这一块
1.一次性把所有id查询出来
2.从第一页到最大页
判断第一页第一个id 是否这样查出来的数据好像少了些,但是db用的次数就多了
我还是用1把功能做出来先,如果有好的有方法告诉我,让我参考下
  

既然是要查询数据库,那么可以这样做

select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表, (select @s:=1) t HAVING id=$id
查询结果中的 page 列就是 id 对应的页号

有点问题,这样才对

select id, page   from (select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表, (select @s:=1) t ) t1  where id=$id

有点问题,这样才对

select id, page   from (select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表, (select @s:=1) t ) t1  where id=$id



@一般用来表示自己定义的一个变量
“:=”主要是用于传递外部参数为语句中变量赋值 

@s:=@s+1   @s:=1  变量赋值两次?
(select @s:=1) t ) t1   t,t1没看懂

这种技巧性的写法要看悟性了
正常的写法是

set @s:=1;select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表

但出于防止sql攻击的考虑,php 不允许同时执行两条及以上指令,所以使用了笛卡尔连接
(select @s:=1) t  只是为了给用户变量 @s 赋初值

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在Laravel中使用Flash会话数据在Laravel中使用Flash会话数据Mar 12, 2025 pm 05:08 PM

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

php中的卷曲:如何在REST API中使用PHP卷曲扩展php中的卷曲:如何在REST API中使用PHP卷曲扩展Mar 14, 2025 am 11:42 AM

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

简化的HTTP响应在Laravel测试中模拟了简化的HTTP响应在Laravel测试中模拟了Mar 12, 2025 pm 05:09 PM

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP记录:PHP日志分析的最佳实践PHP记录:PHP日志分析的最佳实践Mar 10, 2025 pm 02:32 PM

PHP日志记录对于监视和调试Web应用程序以及捕获关键事件,错误和运行时行为至关重要。它为系统性能提供了宝贵的见解,有助于识别问题并支持更快的故障排除

在Codecanyon上的12个最佳PHP聊天脚本在Codecanyon上的12个最佳PHP聊天脚本Mar 13, 2025 pm 12:08 PM

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

解释PHP中晚期静态结合的概念。解释PHP中晚期静态结合的概念。Mar 21, 2025 pm 01:33 PM

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

自定义/扩展框架:如何添加自定义功能。自定义/扩展框架:如何添加自定义功能。Mar 28, 2025 pm 05:12 PM

本文讨论了将自定义功能添加到框架上,专注于理解体系结构,识别扩展点以及集成和调试的最佳实践。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器