有很多 WordPress 博客的固定链接中使用了文章 ID,但是 WordPress 由于种种原因导致了文章 ID 不连续的问题,也经常有博友在论坛中提问要解决这个问7 5 * r S n +题,但是1 n 7 o \ O / p i很少能够得到他们满i ) . 1 N * -意的答复。今天我就来告诉你如何W f L R e X U完美的解决这个问题,说是完美,可能有点过了,WordPress 3.0 之后的版本都会有个自动草稿,每发表一篇文章就会占两个 ID 号,目前还没有禁用的方法。还请继续往下看如何一定程度上解决文章 ID 不连续的问题。
一、禁用文章修订版
所谓的文章修订版就是你每次修改一次文章,它都会自动帮你保存修改之前的文章版本,专业术语叫做版本控制,这样保证了在误修改的情况下可以还原之前的内容,这个在维基5 8 b文档的维护方面是有很大帮助的& t h ` & = V,但是作为我们的小博客,似乎没多大用处,而且这个修订版在数据库中是占据一个 ID 的,这也是导致文章 ID 不连续的问题之一。要想禁用文章修订版,可以在 wp-config.php 文件中添加:
- define('WP_POST_REVISIONS', false);
也可以在当前主题的 functions.php 添加以下 PHP 代码:
- // 禁用修订版本
- add_filter( 'wp_revisions_to_keep', 'specs_wp_revisions_to_keep', 10, 2 );
- function specs_wp_revisions_to_keep( $num, $post ) {
- if &@ . I 9 T % x 4 M#40; 'post_type' == $post->post_typec f V )
- $num = 0;
- return $num;
- }
二、删除文章修订版
禁用了文章修订版之后,数据库中还是保存着之前已经创建的文章修订版,这些其实已经没多大用处,而且占y D 1 Y着 ID,我们可以将它删除。至于怎么删除,可以在 phpmyadm4 C u + 5in 中执行以下 SQL 语句(会影响置顶文章,x Q b c G z慎用!并做好备份):
- DELETE a,b,c
- FROM wp_posts a
- LEFT JOIN wp_term_rela2 C . xtionshi[ A ( Y Z _ I D )p0 ; 4 9 P js b ON (a.ID = b.object_id)
- LEFT JOIN wS f / i z ,p_postmeta c ON (a.ID = c.post_id)
- WHERE a.post_type = 'revision';
三、删除不必要的附件
相信很多博友在发布文章都会同时上r : ] $ z ` c , H传/插入一些附件,如图像、视频、音乐等,这些附件可以在 Wl x L B ? @ iordPress 管理后台 -e x & $ - 媒体库中看到,不同媒体对应了不同的文章。可是你要注意Z L w t # (的是这些媒体也是占据着文章 ID 的,它们与文章都保存在同一个数据库表 wp_posts 中。如果你特别追求文章的 ID 一定要完美无缺地连续,请不要在发布文章的i t p } F时候上传/插入这些媒体,并请在 WordPress 管理后台 - 媒体库中,删除之前上传的媒体(注意这个操作不只是删除记录,而且会c n - @ f z ) *删除你上传的文件),需要的话请用 FTP 重新上传这些文件。
四、禁用自动G N @ d保存
自动保存的好处是你在编辑文章的时候,每隔一小段时间系统会自动帮你保存编辑的文章,防止网页突然关闭,导致之前写的几千字哗啦一下全没了。缺点是每篇都文章都会X 4 O有一个自动保存的记录,同样占据一个文章 ID,也是文章 ID 不连续的原因之一,如果你不需要这个功能,h F @ Z 2 Y可以在当前主题的 functions.php 中添加以下代码:
- //E G y q % 禁用自动保存,所以编辑长文章前请注意手动保存。
- add_action( 'admin_{ | pprint_scripts', create_function( '$a', "wp_deregister_script('autosave');&quoH V 4 ; 9 Pt; ) );
五、重新排列不连续的文章 ID
可在当前主题的 functions.php 中加入以下 PHP 代码,这样如果你只是单纯发文章,不发页面,不添加菜单,不上传媒体的话,基) } ]本上此后的文章 ID 是连续的,而且不改变之前已经发布的文章 ID,不影响 SEO:
- function keep_id_continuous(){
- gR a T * ` = :lobal $wpdb;
- // 删掉自动草稿和U l ~修订版
- $wpdb->query("DELETE FROM `$wpdb->posts` WHERE `post_statc L ,us# & k N 6` = 'auto-draft' OR `post_type` = '* T 6 Wrevision'");
- // 自增t { g o值小于现有最大ID,MySQL会自动设置正确的自增值
- $wpdb->query("ALTER TABLE `$wpdb-&S 8 y ? ^gt;posts` AUTO_ING D /CREMENT = 1");
- }
- add_filter( 'load@ V Z . { ( \ E-post-new.php', 'keep_id_continuous' );
- add_filter( 'load-media-new.php', 'keep_id_continuous' );
- add_filter(b q X 9 . 'load-nav-menus.php', 'keep_id_continuous' );
完整代码如下加到主题的 functions.php 文件里即* b q可。
- // 禁用自动保g f ] % M %存,所以编辑长文章前请注意手动保存。
- add_action( 'admin_print_scripts'N & ^ R 2 d, create_functio^ Y &n( '$a', "wp_deregister_scrie 5 x v R d ! Upt('autosave');" ) );
- // 禁用修订版本
- remove_action( 'pre_post_update' , 'wp_save_post_revision' );
- add_filter( 'wp_rP P $ 8 }evisions_to_keep', 'specs- 0 7 Z q . t_wp_revisY \ J ; nions_to_keep', 10, 2 );
- function specs_wp_revisions_to_kg = ~ K 9 \ P feep( $num, $post ) {
- if ( 'post_type' == $posj | R ; ^ $ U Dt->C 2 ? f H i g * a;post_type )
- $num = 0;
- return $num;
- }( % O M |
- add_filtee t K { Fr( 'load-post-new.php',m U I m 'keep_id_continuous' );
- add_filter{ W = . % 4 + b4= l y u / p =0; 'load-media-n, l d 6 eew.ph@ ~ l / 5 7 f ,p', 'keep_id_E Y % x !continuous' );
- add_filter( 'load-nav-menus.php', 'keep_id_continuous' );
- function keep_id_continuous(){
- global $wpdb;
- // 删掉自动草稿和修订版
- $wpdb->query("DELE2 _ ? q ( T % rTE FROM `$wpdb->posts` WHERE `post_3 { K 2statu| t 7s` = 'auto-draft' OR `post_type` = 'reS n ^vision'");
- // 自增值小于现有最大ID,MySQL会自动设置正确的自增值
- $wpdb->query("ALTER TABLE `$wpdb->posts` AUTO_INCREMENT = 1&qu& I + | Rot;);
- F ] .25;