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

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

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

1. 禁用文章修订版

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

define('WP_POST_REVISIONS', false);

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

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

2. 删除文章修订版

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

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

3. 删除不必要的附件

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

4. 禁用自动保存

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

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

5. 重新排列不连续的文章ID

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

function keep_id_continuous(){
    global $wpdb;
    $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");
    $wpdb->query("DELETE FROM $wpdb->posts WHERE ( post_status = 'auto-draft' OR ( post_status = 'inherit' AND post_type = 'revision' ) ) AND ID > $lastID");
    $wpdb->query("ALTER TABLE $wpdb->posts AUTO_INCREMENT = 1");
}
// 将函数钩在新建文章、上传媒体和自定义菜单之前。
add_filter( 'load-post-new.php', 'keep_id_continuous' );
add_filter( 'load-media-new.php', 'keep_id_continuous' );
add_filter( 'load-nav-menus.php', 'keep_id_continuous' );
// 禁用自动保存,所以编辑长文章前请注意手动保存。
add_action( 'admin_print_scripts', create_function( '$a', "wp_deregister_script('autosave');" ) );
// 禁用修订版本
remove_action( 'pre_post_update' , 'wp_save_post_revision' );

6. 安装插件 WP Clean Up

选择这个的插件的原因有以下几点:
第一,如果喜欢在文章中添加一些匹配的元素,比如图片,音乐,视频等以丰富文章.
第二,使用这个插件只要我们不定期的去清楚这些相关数据,那么文章ID连续性就不会有非常大的不连续. 数值不会很大,最多就间隔几个. 同时此插件还可以优化数据库表.

安装插件WP Clean Up.

Last modification:October 9th, 2018 at 09:31 am