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

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

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

答案:有的!

以下分页方法查询会更快

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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 "<li>"; previous_posts_link('上一页');echo"</li>";
        if ( $max_page >$range ) {
             if( $paged <$range ) {
             for( $i = 1; $i <= ($range +1); $i++ ) {
                     echo "<li><a href='".get_pagenum_link($i) ."'";
                     if($i==$paged) echo " class='current'";echo ">$i</a></li>";
             }
             }elseif($paged >= ($max_page -ceil(($range/2)))){
                 for($i = $max_page -$range;$i <= $max_page;$i++){
                     echo "<li><a href='".get_pagenum_link($i) ."'";
                     if($i==$paged)echo " class='current'";echo ">$i</a></li>";
                 }
             }elseif($paged >= $range &&$paged <($max_page -ceil(($range/2)))){
                     for($i = ($paged -ceil($range/2));$i <= ($paged +ceil(($range/2)));$i++){
                     echo "<li><a href='".get_pagenum_link($i) ."'";if($i==$paged) echo " class='current'";echo ">$i</a></li>";
                     }
                }
         }else{
                 for($i = 1;$i <= $max_page;$i++){
                     echo "<li><a href='".get_pagenum_link($i) ."'";
                     if($i==$paged)echo " class='current'";echo ">$i</a></li>";
                 }
            }
         echo "<li>";next_posts_link('下一页');echo"</li>";
         echo '<li><span>共'.$max_page.'页</span></li>';
     }
}

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

1
<?php get_pagenavi();?>

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

原文链接:https://xiaohost.com/10435.html,转载请注明出处。
0

评论0

请先