找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 744|回复: 0
打印 上一主题 下一主题

PHP分页效率终结版(推荐)

[复制链接]

2588

主题

2588

帖子

7694

积分

论坛元老

Rank: 8Rank: 8

积分
7694
跳转到指定楼层
楼主
发表于 2018-2-14 08:16:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            这里仅展示出设计思路,具体安全问题,是否同步更新等可根据具体需求添加修改:
以前人们常用的PHP分页技术,通常都需要先统计出数据库中总信息条数才能判断出总页数并对其进行分页,,也就是说,每次分页要对数据库进行两次调用,在面临大数据量,高并发查询情况下是很不效率的,曾经一直为这个问题烦恼但都没想到合适的解决方法,今天突然在睡梦中 遇见奇迹...具体分析原理如下:(红色部分为优化后的区别,思路采用最原始的代码书写,为了照顾新人)
原始分页技术:包括许多开源程序也在使用的技术;
一般都是对数据库信息进行统计,然后调用分页类,进行分页,,每次都要经过2次数据库查询操作
例(原始分页技术):  每次都要进行2次数据库查询
[U]复制代码[/U] 代码如下:
    $sqlstr="select  count(*)  as total  from  tablename";
    $sql=mysql_query($sql) or die("error");
 $info=mysql_fetch_array($sql);  //第一次 数据库调用
    $total=$info["total"];//每次翻页都要进行 总信息条数 的数据库查询操作
    $pagesize=10; //每页显示数量
    $page=$_GET["page"]?max(intval($_GET["page"]),1):1;//当前页
    if($total){,
      $sql="select * from  tablename  limit "($page-1)*$pagesize",$pagesize";
      $sql=mysql_query($sql) or die("error");//第二次数据库查询操作
      $info=mysql_fetch_array($sql);
   do{
    ...............
            }while($info=mysql_fetch_array($sql));
            include("page_class.php");//调用分页类
            $url="url.php?page=" //假设当前页为 URL.PHP
            echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 为要分页的URL地址
   }
   //优化后的分页技术(只需在第一次调用时进行信息统计即可)
    if(isset($_GET["total"])){   //只需要进行一次总信息条数的统计即可
   $total=intval($_GET["total"]);
//以后的的总信息数量通过GET传递即可,节省了1/2的数据库负荷,,,,
    }else{
      $sqlstr="select  count(*)  as total  from  tablename";
      $sql=mysql_query($sql) or die("error");
   $info=mysql_fetch_array($sql);  //第一次 数据库调用
            $total=$info["total"];
    }//总信息条数
    $pagesize=10; //每页显示数量
    $page=$_GET["page"]?max(intval($_GET["page"]),1):1;//当前页
    if($total){
      $sql="select * from  tablename  limit "($page-1)*$pagesize",$pagesize";
      $sql=mysql_query($sql) or die("error");//第二次数据库查询操作
      $info=mysql_fetch_array($sql);
   do{
    ...............
            }while($info=mysql_fetch_array($sql));
            include("page_class.php");//调用分页类
   $url="url.php?total=$total&page=" //假设当前页为 URL.PHP
            echo $get_page=new get_page($url,$total,$pagesize,$page); //URL 为要分页的URL地址
   }
            
            
您可能感兴趣的文章:
  • PHP动态分页函数,PHP开发分页必备啦
  • php开发分页实现代码
  • php分页思路以及在ZF中的使用
  • PHP 文本文章分页代码 按标记或长度(不涉及数据库)
  • 无JS,完全php面向过程数据分页实现代码
  • php 解决旧系统 查出所有数据分页的类
  • php中长文章分页显示实现代码
  • 仿Aspnetpager的一个PHP分页类代码 附源码下载
  • 精美漂亮的php分页类代码
  • 使用PHP+JQuery+Ajax分页的实现
  • 用php制作简单分页(从数据库读取记录)的方法详解
  • thinkphp 一个页面使用2次分页的实现方法
  • 实用的简单PHP分页集合包括使用方法
  • 学习php分页代码实例
  • 一个简单且很好用的php分页类
  • PHP分页详细讲解(有实例)
  • php实现分页工具类分享
  • php分页代码学习示例分享
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端