Jadual Kandungan
回复讨论(解决方案)
Rumah pembangunan bahagian belakang tutorial php 查出当前id所在的页面

查出当前id所在的页面

Jun 23, 2016 pm 01:22 PM

字段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就是它所在的页面
Salin selepas log masuk




回复讨论(解决方案)

假定 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
Salin selepas log masuk
如果 id 是乱序的,一样也可计算
$id = 9;$a = array(1,5,9,2,10);$x = 2;$p = array_search($id, $a);echo ceil($p / $x) + 1; //2
Salin selepas log masuk

这种只能是把所有的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 是否<已知id 是的话第二页第一个id 是否<已知id ........
这样查出来的数据好像少了些,但是db用的次数就多了
我还是用1把功能做出来先,如果有好的有方法告诉我,让我参考下

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

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

有点问题,这样才对

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

有点问题,这样才对

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



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

@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 表
Salin selepas log masuk

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

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Apr 06, 2025 am 12:02 AM

Sesi rampasan boleh dicapai melalui langkah -langkah berikut: 1. Dapatkan ID Sesi, 2. Gunakan ID Sesi, 3. Simpan sesi aktif. Kaedah untuk mengelakkan rampasan sesi dalam PHP termasuk: 1. Gunakan fungsi Sesi_Regenerate_ID () untuk menjana semula ID Sesi, 2. Data sesi stor melalui pangkalan data, 3.

Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Apr 03, 2025 am 12:04 AM

Penerapan prinsip pepejal dalam pembangunan PHP termasuk: 1. Prinsip Tanggungjawab Tunggal (SRP): Setiap kelas bertanggungjawab untuk hanya satu fungsi. 2. Prinsip Terbuka dan Tutup (OCP): Perubahan dicapai melalui lanjutan dan bukannya pengubahsuaian. 3. Prinsip Penggantian Lisch (LSP): Subkelas boleh menggantikan kelas asas tanpa menjejaskan ketepatan program. 4. Prinsip Pengasingan Antara Muka (ISP): Gunakan antara muka halus untuk mengelakkan kebergantungan dan kaedah yang tidak digunakan. 5. Prinsip Inversi Ketergantungan (DIP): Modul peringkat tinggi dan rendah bergantung kepada abstraksi dan dilaksanakan melalui suntikan ketergantungan.

Bagaimana cara debug mod CLI dalam phpstorm? Bagaimana cara debug mod CLI dalam phpstorm? Apr 01, 2025 pm 02:57 PM

Bagaimana cara debug mod CLI dalam phpstorm? Semasa membangun dengan PHPStorm, kadang -kadang kita perlu debug PHP dalam mod Interface Line Command (CLI) ...

Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Mar 31, 2025 pm 11:54 PM

Bagaimana untuk menetapkan keizinan UnixSocket secara automatik selepas sistem dimulakan semula. Setiap kali sistem dimulakan semula, kita perlu melaksanakan perintah berikut untuk mengubahsuai keizinan UnixSocket: sudo ...

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Bagaimana cara menghantar permintaan pos yang mengandungi data JSON menggunakan perpustakaan php curl? Bagaimana cara menghantar permintaan pos yang mengandungi data JSON menggunakan perpustakaan php curl? Apr 01, 2025 pm 03:12 PM

Menghantar data JSON menggunakan perpustakaan Curl PHP dalam pembangunan PHP, sering kali perlu berinteraksi dengan API luaran. Salah satu cara biasa ialah menggunakan perpustakaan curl untuk menghantar post ...

See all articles