WordPress完美解决文章ID不连续和冗余数据问题的方法汇总

  • A+
所属分类:建站

前段时间,有朋友说为什么wordpress在发表文章的时候文章的ID不连续,感觉好像缺少了文章造成的一样,其实王晟璟也发现此问题了,由于一些事情的耽搁也就一直没有去理睬这个问题,但王晟璟知道并不是网友说的是因缺少文章造成ID不连续的。我们很多WordPress博客系统的使用者基本都设置了的固定链接,伪静态的设置,当然即便不是设置伪静态也会产生这样的问题。王晟璟亲自在本地试用过。

从资料上看,在WordPress 3.0 之后的版本都会有个自动草稿,每发表一篇文章就会占两个ID号,而细心的朋友在发表文章的时候也会发现自动保存草稿的功能,另外还有一个就是在我们发表完一篇文章后,如果对文章进行修改,那么这时同样会产生自动保存草稿以及还会新行成一个修订版,该多少次就会存在多少此修订版,他们都会占用相应的文章ID。目前还没有禁用的方法。

那我们如何完美的解决这个问题呢,王晟璟百度了下相关关键词,最后发现在露兜博客中有比较完美的解决方案以及其他一些没有署名的地方看见的方法,所以借此机会就摘录整理出来,希望能给他有这类需求的朋友们帮助,在此也非常感谢露兜博客的博主以及小虾博主整理的解决方案以及未署名的其他朋友们。

WordPress完美解决文章ID不连续和冗余数据问题的方法汇总

WordPress完美解决文章ID不连续和冗余数据等问题的方法汇总

ps:当然如果你的固定链接中没有使用[%post_id%],那么对你来说文章ID是透明的,无关紧要。即使固定链接中用了[%post_id%],如果你不是特别在意,连不连续也是无关紧要的,本文对你来说也没多大意义了。

一、禁用文章修订版

所谓的文章修订版就是大家在每次修改一次文章,wordpress博客都会自动帮你保存修改之前的文章版本,专业术语叫做版本控制,这样保证了在误修改的情况下可以还原之前的内容,这个在维基文档的维护方面是有很大帮助的,但是作为我们的小博客,似乎没多大用处,而且这个修订版在数据库中是占据一个ID的,这也是导致文章ID不连续的问题之一。那么要想禁用文章修订版,可以在 wp-config.php文件中添加:

 

  1. define('WP_POST_REVISIONS', false);

 

也可以在当前主题的functions.php添加以下PHP代码:

  1. // 禁用修订版本
  2. remove_action( 'pre_post_update' , 'wp_save_post_revision' );

 

二、删除文章修订版

禁用了文章修订版之后,在我们网站的数据库中还是保存着之前已经创建的文章修订版,这些其实已经没多大用处,而且占着ID,我们可以将它删除。那怎么删除,我们可以在phpmyadmin中执行以下SQL语句(建议在超作之前先做好备份,以免带来不必要的麻烦,同时使用此功能会影响已经置顶的文章,慎用!):

 

  1. DELETE a,b,c
  2. FROM wp_posts a
  3. LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)
  4. LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)
  5. WHERE a.post_type = 'revision';

 

三、删除不必要的附件

相信很多博友在发布文章的时候为了增加页面的丰富性都会同时上传插入一些附件,如图像、视频、音乐等,(至少王晟璟会在文章中插入相匹配的一些元素来丰富文章的阅读性)这些附件可以在WordPress管理后台中的媒体库看到,不同媒体对应了不同的文章。而这些媒体也是占据着文章ID造成文章ID不连续的原因之一,它们与文章都保存在同一个数据库表wp_posts中。如果我们特别追求文章的ID一定要完美无缺地连续,那最好的建议就是请不要在发布文章的时候上传/插入这些媒体,并请在WordPress管理后台中的媒体库删除之前上传的媒体(注意这个操作不只是删除记录,而且会删除你上传的文件),需要的话请用FTP重新上传这些文件。

四、禁用自动保存

wordpress博客系统的自动保存功能的好处是你在编辑文章的时候,每隔一小段时间系统就会自动帮你保存编辑的文章,防止网页突然关闭,导致之前写的几千字哗啦一下全没了。缺点是每篇都文章都会有一个自动保存的记录,而这些记录也同样占据一个文章ID,也是文章ID不连续的原因之一,如果你不需要这个功能,可以在当前主题的functions.php中添加以下代码来达到禁用自动保存的功能:

 

  1. // 禁用自动保存,所以编辑长文章前请注意手动保存。
  2. add_action( 'admin_print_scripts', create_function( '$a', "wp_deregister_script('autosave');" ) );

 

五、重新排列不连续的文章ID

方法一:可在当前主题的functions.php中加入以下PHP代码,这样如果你只是单纯发文章,不发页面,不添加菜单,不上传媒体的话,基本上此后的文章ID是连续的,而且不改变之前已经发布的文章ID,不影响SEO(代码参考自:小虾):

 

  1. function keep_id_continuous(){
  2.     global $wpdb;
  3.     $lastID = $wpdb->get_var("SELECT ID FROM $wpdb->posts WHERE post_status = 'publish' OR post_status = 'draft' OR post_status = 'private' OR ( post_status = 'inherit' AND post_type = 'attachment' ) ORDER BY ID DESC LIMIT 1");
  4.     $wpdb->query("DELETE FROM $wpdb->posts WHERE ( post_status = 'auto-draft' OR ( post_status = 'inherit' AND post_type = 'revision' ) ) AND ID > $lastID");
  5.     $wpdb->query("ALTER TABLE $wpdb->posts AUTO_INCREMENT = 1");
  6. }
  7. // 将函数钩在新建文章、上传媒体和自定义菜单之前。
  8. add_filter( 'load-post-new.php', 'keep_id_continuous' );
  9. add_filter( 'load-media-new.php', 'keep_id_continuous' );
  10. add_filter( 'load-nav-menus.php', 'keep_id_continuous' );
  11. // 禁用自动保存,所以编辑长文章前请注意手动保存。
  12. add_action( 'admin_print_scripts', create_function( '$a', "wp_deregister_script('autosave');" ) );
  13. // 禁用修订版本
  14. remove_action( 'pre_post_update' , 'wp_save_post_revision' );

 

如果你使用了置顶文章、菜单和父子页面等功能,那下面的方法将会失效:

方法二:完成以上几步,基本上可以保证以后发布的文章ID都会是连续的了,但是之前已经发布的文章ID还是一片混乱,得把他们重新排列,以保证是ID是连续的。露兜博客博主写了一个PHP脚本,大家可以下载后用文本编辑器打开,根据开头的说明修改数据库信息,然后将该PHP文件上传至你的博客空间,运行一下看到OK就可以了,完了之后就可以到phpmyadmin中查看wp_posts表中的id是不是连续的了。还是那句话,开始之前请先备份你的数据库。(在这里不得不提到露兜博客博主的再三强调:如果你使用了[%post_id%]作为固定链接,那么将可能改变所有文章的网址,会影响搜索引擎收录;如果你用的插件建立了新的数据库表,如投票插件等,也将会出现问题;如果你的博客中创建了父子关系的页面,运行了以下脚本将会失去此关系。请慎用!)再次感谢您们的辛苦付出。

脚本下载:

 

六:安装插件让此问题变小。

当然这也是博主王晟璟经过思考后的选择。选择这个的插件的原因有以下几点:第一,本人比较喜欢在文章中添加一些匹配的元素,比如图片,音乐,视频等以丰富文章。第二,使用这个插件只要我们不定期的去清楚这些相关数据,那么文章ID连续性就不会有非常大的不连续。数值不会很大,最多就间隔几个。同时此插件还可以优化数据库表。对于这样的结果王晟璟非常满意,如果你喜欢那么也可以采用我这种方法。也分享出来供大家选择吧。

安装插件[WP Clean Up]

①、可以下载插件包然后上传到wp-content/plugins/目录下进行安装。

下载插件也在上面的下载按钮中选择即可。

②、当然我们也可以直接在后台搜索此插件名称后直接安装启用即可。

WordPress完美解决文章ID不连续和冗余数据问题的方法汇总

WP Clean Up

WordPress完美解决文章ID不连续和冗余数据问题的方法汇总

WP Clean Up

 

 

 

 

 

 

 

 

 

 

 

通过图中我们可以看出这个插件给出了很多项的清理,同时还可以优化数据库。非常满足。

文件下载

avatar

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:15   其中:访客  10   博主  5

    • avatar 我是萌萌的tenven 0

      正为这个问题刚到苦恼呢,看到博主的文章试了一下,感觉不错。谢谢分享!

      • avatar songlucky.com 0

        有个问题,此法以后新文章id仍然是接着最后一个开始排序的,能不能将以前跳过得id补上。如何实现?

          • avatar leejon 0

            @songlucky.com 我有个思路,新发表文章后,数据库修改新ID为旧ID,但可能要考虑的是效率问题。

          • avatar 李建林博客 0

            不错,博主是高手啊,我正在为这个问题发愁啊

              • avatar 王晟璟 Admin

                @李建林博客 我也是百度学习到的,希望对你有帮助。互相学习,共同进步啊 评论” />

              • avatar 香港虚拟主机 4

                可以试一试

                • avatar 噶里味美食网 1

                  我的博客文章id就是不连续的,尼玛

                    • avatar 王晟璟 Admin

                      @噶里味美食网 那你可以试试上面的,我在本地测试没有问题。不过最后我采用了第六。 评论” />