WordPress删除文章多余的自定义字段及值

Author: 陌小雨Date: 2016-02-14View: 65

曾经启用过多说或者其他插件的个人博客,数据库会残留一些自定义字段,拿多说为例,会残留名为duoshuo_thread_id的自定义字段及值

global $wpdb;
$wpdb->query( "
DELETE FROM $wpdb->postmeta
WHERE `meta_key` = 'duoshuo_thread_id'
" );

将上述代码加入到主题的functions.php文件中,然后刷新一下后台删除即可,再在任一篇文章编辑界面刷新就不会再看到duoshuo_thread_id自定义字段了。如果要删除其他的自定义字段,更改下上面代码中的自定义字段名相同操作即可。

2017-10-14日更新

如果想一次性删除多个自定义字段,只需要将倒数第二行更改为:WHERE `meta_key` = 'duoshuo_thread_id' or `meta_key` = '字段名2' or `meta_key` = '字段名3'

依次类推,举一反三。也适合下面的sql命令

还有一种稍微麻烦的办法,就是在数据库中用sql命令行:

DELETE FROM wp_postmeta WHERE meta_key ='duoshuo_thread_id';

sql命令行操作方法详见这篇文章:如何删除WordPress所有文章