字段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 的分布情况
不连续?那就需要知道 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 = 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的编号,
$页号 = ceil( $编号 / 8);
关于id这一块
1.一次性把所有id查询出来
2.从第一页到最大页
判断第一页第一个id 是否<已知id 是的话第二页第一个id 是否<已知id ........
这样查出来的数据好像少了些,但是db用的次数就多了
我还是用1把功能做出来先,如果有好的有方法告诉我,让我参考下
既然是要查询数据库,那么可以这样做
select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表, (select @s:=1) t HAVING id=$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
这种技巧性的写法要看悟性了
正常的写法是
set @s:=1;select id, ceil(@s/每页行数) as page, @s:=@s+1 from 表