wordpress进行Mysql查询很慢之SQL_CALC_FOUND_ROWS改进

作者: 站长 上传时间: 浏览: N/A 下载: N/A 格式: N/A 评分: N/A

SQL_CALC_FOUND_ROWS查询主要是解决文章计数,进而进行分页处理,列表页查询耗时主要在这个上面

有没有更好的解决办法呢?

答案:有的!

以下分页方法查询会更快

function get_pagenavi( $range = 4 ) {
global $paged,$wp_query;
if ( !$max_page ) {
$max_page = $wp_query->max_num_pages;
}
if( $max_page >1 ) {
if( !$paged ){
$paged = 1;
}
echo "

  • "; previous_posts_link('上一页');echo"
  • ";
    if ( $max_page >$range ) {
    if( $paged <$range ) { for( $i = 1; $i <= ($range +1); $i++ ) { echo "

  • $i
  • ";
    }
    }elseif($paged >= ($max_page -ceil(($range/2)))){
    for($i = $max_page -$range;$i <= $max_page;$i++){ echo "

  • $i
  • ";
    }
    }elseif($paged >= $range &&$paged <($max_page -ceil(($range/2)))){ for($i = ($paged -ceil($range/2));$i <= ($paged +ceil(($range/2)));$i++){ echo "

  • $i
  • ";
    }
    }
    }else{
    for($i = 1;$i <= $max_page;$i++){ echo "

  • $i
  • ";
    }
    }
    echo "

  • ";next_posts_link('下一页');echo"
  • ";
    echo '

  • 共'.$max_page.'页
  • ';
    }
    }

    然后在需要分页的地方使用以下代码调用

    分页的ul li标签的css请自行定义,上述只给出了php方法

    Leave a Comment