WordPress如何刪除文章修訂版本和自動保存的草稿
[重要通告]如您遇疑難雜癥,本站支持知識付費業務,掃右邊二維碼加博主微信,可節省您寶貴時間哦!
在使用WordPress建站的站長們都知道WordPress自動記錄文章修訂版本的功能,每次編輯或修改文章,系統都會自動生成并保存一個修訂版,長此以往數據庫將產生大量數據冗余,最終拖慢網站的運行速度。這時的我們就需要定期清理或永久關閉此功能。
清理文章修訂
打開主當前主題文件夾在wp-content/themes
文件夾中的 functions.php
,將如下代碼添加至文件末尾的?>
前,保存。
$wpdb->query( "
DELETE FROM $wpdb->posts
WHERE post_type = 'revision'
" );
使用說明:
打開網站任意文章刷新,返回wordpress后臺可以看到歷史修訂版本已被清理干凈,然后刪除上述代碼,需要清理時再添加。
PS:還有一種在PHPMyAdmin 中通過SQL 語句可以刪除它們的方式方法,SQL語句如下:
DELETE?FROM?wp_postmeta?WHERE?post_id?IN?(SELECT?id?FROM?wp_posts?WHERE?post_type?=?'revision');
DELETE?FROM?wp_term_relationships?WHERE?object_id?IN?(SELECT?id?FROM?wp_posts?WHERE?post_type='revision');
DELETE FROM wp_posts WHERE post_type='revision';
一勞永逸的關閉修訂:
WordPress 提供了關閉修訂的方法,在 wp-setting.php
?中有一個變量?WP_POST_REVISIONS
,把它設置為?false
?就可以屏蔽 WordPress 日志修訂功能。
操作過程:打開網站根目錄,找到配置文件wp-config.php
將下方代碼添加其中,保存即可。
define('WP_POST_REVISIONS', false);
PS:還一種方法就是:
在wp-config.php 添加下面一行:
在 $table_prefix = 'wp_'; 前面添加下面的兩行代碼:
define(‘WP_POST_REVISIONS’, false); //禁用歷史修訂版本
define(‘AUTOSAVE_INTERVAL’, 86400); //設置自動保存時間設置為一天
再來個簡單的只要在自己使用的網站主題的模板函數functions.php文件里面加入下面的代碼:
function disableAutoSave(){ wp_deregister_script('autosave'); } add_action( 'wp_print_scripts', 'disableAutoSave' );
保存并上傳覆蓋,這樣WordPress的自動保存草稿功能就禁用了;
2019.08.01追加:
針對文章修訂版本解決方案:
主題目錄下 wp-content\themes\theme\functions.php 或者 全局 wp-includes\functions.php 增加如下代碼
//禁用文章修訂版本開始 add_filter( 'wp_revisions_to_keep', 'specs_wp_revisions_to_keep', 10, 2 ); function specs_wp_revisions_to_keep( $num, $post ) { return 0; } //禁用文章修訂版本結束
延伸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';
刪除自動保存的草稿:
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_status = 'auto-draft';
通過以上的操作,我們就可以解決WordPress刪除文章修訂版本和自動保存的草稿的相關內容;
問題未解決?付費解決問題加Q或微信 2589053300 (即Q號又微信號)右上方掃一掃可加博主微信
所寫所說,是心之所感,思之所悟,行之所得;文當無敷衍,落筆求簡潔。 以所舍,求所獲;有所依,方所成!