快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

给何版主, 机器民主和lilyxie: 关于分页机制.

1. 分页的前提是记录按id排序, 且不连续, 比如有些记录被删除,
   或者要分页显示查找结果, 这样就有了除分页外的条件$q
2. 确定分页的方法:
(1): 用简朴的"页首, 上一页, 下一页".
(2): 用"1,2,3,4,5,6,..........末尾"来指定跳到某页.
3. 实现分析:
(1) 假如先查询全部结果, 只显示其中的部分. 这种方法显然不好,
    会累坏server.
(2) 对于用limit m,n实现分页, 有些不负责, 服务器在实际操作时还是
    按$q条件找出所有结果, 然后只返回m后的n条. server工作仍旧很多.
(3) 优化的办法是知道要显示页的起始$id, 查询
   "where $q and id>=$id order by id desc limit 0,$page_length"
   这样mysql 会先按id的索引找到符合条件的id, 然后再评估$q.
(4) 那$id怎么来呢?
(5) 对于显示方法1, 每页多查询一条,最后一个记录的$id就是啦
    "where $q and id>=$id order by id limit 0,$page_length+1"
    if (mysql_num_rows($result) > $page_length) echo "下一页"
   //(记住最后一条记录不要显示!)
   //假如不使用第二种分页方法, 到此结束.
(5) 对于显示方法2, 后面$page_offset=6页的每页起始id要一次知道.
"select id from xxxx where $q order by id desc limit 0,$page_length*$page_offset"
for($i=0;$i*$page_length<$mysql_num_rows($result);$i++){
    $start=mysql_result($result,$i*$page_length,0);
    echo \\'<a href="xxxxx?pageno=\\'.($i+1)."&id=$start/">";
    if ($id==$start) echo "<b>$i</b>"; //加重显示当前页号
    else echo $i;
    echo "</a>";
}
(6)也许有人要问server不是按$q条件把所有这几页都搜一遍了吗?
和"limit 0,$page_length*$pageno"有什么区别? 直接用$pageno哪有$id这么麻烦?
答案是可以利用session功能存起来这个结果, 假如$q没有变, 就可以直接调用,
省得每次换页都折腾数据库.
加上后续页面判定, 上面的例子就变成:
//假如$q没有变化
$page_offset=6;
session_register($ids);
if (!$ids){//后序页面不会执行
    "select id from xxxx where $q order by id desc limit 0,$page_length*$page_offset+1";//判定有无后序页面
    for($i=0;$i*$page_length<$mysql_num_rows($result);$i++){
        $ids[]=mysql_result($result,$i*$page_length,0);
    }
}
//有乐$ids......
for ($i=0;$i<$page_offset;$i++){
    echo \\'<a href="xxxxx?id="$ids[$i].\\'">\\';
    if ($d==$ids[$i]) echo "<b>$i</b>"; //加重显示当前页号
    else echo $i;
    echo "</a>";
}
//下面这句自由发挥, 可以切换到分页模式1
if ($ids[$page_offset])
    echo \\'<a href="xxxx?pageno=\\'.($pageno+1).\\'&id=\\'.$ids[$page_offset].">....</a>\\';
(8) 以上结果稍加改动, 可以session_resiter($pageno), 来记录当前是第几
大页. 类似快进功能.
(7) 不知道php4正式版是否支持session中存放数组, 假如不行建议用
implode/explode来变成字串保存.
(8) 这种方法的长处应该是速度快, 但缺点是不知道总共符合$q条件的数量.
对于搜索庞大的数据库应该有用.
(9) 实现"跳至末尾", 可以在以上sql语句中 order by id, 不要desc. 同理可实现
前面第N页.
4 以上代码还都是设想, 希望各位多多指正.
5 本文中央思想是利用id索引和id的偏移来迅速查找后序内容, 节省数据库开销.





返回类别: 教程
上一教程: PHP两种安装模式的区别
下一教程: 用PHP制作动态计数器

您可以阅读与"给何版主, 机器民主和lilyxie: 关于分页机制."相关的教程:
· Php+MySql分页机制两种方案的比较测试:
· 关于文本留言本的分页代码
· 发布一个最强的PHP通用分页类
· 回复:关于PHP聊天室的讨论
· 关于PHP事件驱动问题之我见
    微笑服务 优质保证 索取样品