WordPress删除文章时自动删除图片附件和删除媒体库内所有文件的方法

前几天小熊复制了一个测试站点,想用来测试一下些插件和新功能,就把数据库的很多资料全部删除,但发现媒体库中的文件还存在,网上找教程,发现可以这样解决,因为wordpress的图片以及文章数据都是储存在wp-posts这一个数据表里面的,删除wp-posts表里面的所有媒体文件记录就可以解决了。

DELETE FROM wp_posts WHERE NOT(post_status = 'publish' AND post_type IN('post','nav_menu_item','page'));

这句的意思是在wp_posts表中删除文章状态(post_status)不是发布(publish)状态,并且文章类型(post_type)不是文章(post)、导航菜单(nav_menu_item)或者页面(page)的所有文章。

小熊网上找的,实测可以正常删除,希望帮助用到的人,但一定慎用,这样会删除所有没有添加在文章里的图片,有可能误删除你上传在媒体库的小图标等等,一定提前做好备份。

WordPress删除文章时,文章内所上传到媒体库的图片等附件不会自动删除,占用了网站空间,因此下面说明通过几行代码的简单方式实现在删除文章时自动删除缩略图以及图片附件,这样就不用手动去媒体库寻找并删除,准确而且效率高。将下面代码放到主题functions.php文件的最下面即可添加成功

/* 删除文章时删除图片附件 */  
function delete_post_and_attachments($post_ID) {  
        global $wpdb;  
        //删除特色图片  
        $thumbnails = $wpdb->get_results( "SELECT * FROM $wpdb->postmeta WHERE meta_key = '_thumbnail_id' AND post_id = $post_ID" );  
        foreach ( $thumbnails as $thumbnail ) {  
        wp_delete_attachment( $thumbnail->meta_value, true );  
        }  
        //删除图片附件  
        $attachments = $wpdb->get_results( "SELECT * FROM $wpdb->posts WHERE post_parent = $post_ID AND post_type = 'attachment'" );  
        foreach ( $attachments as $attachment ) {  
        wp_delete_attachment( $attachment->ID, true );  
        }  
        $wpdb->query( "DELETE FROM $wpdb->postmeta WHERE meta_key = '_thumbnail_id' AND post_id = $post_ID" );  
}  
add_action('before_delete_post', 'delete_post_and_attachments');

 

 

本图文属小熊原创或转载整理,未经允许请勿私自转载--青州小熊 » WordPress删除文章时自动删除图片附件和删除媒体库内所有文件的方法
微信公众号:大熊正品
关注小熊服务号,小熊第一时间更新到货,分享更多好玩的东西。
191815人已关注
赞(0)

留言2

  • 昵称 (必填)
  • (邮箱) (必填)
  1. #2
    小熊的网站调优还是很nb的。那么多sku都能搞。
    黑李白2022-09-28 11:59:26回复
  2. #1
    www.7ycc.com感谢老大的技术帖子,完美解决了问题
    cofeting2020-04-25 12:29:27回复
主页 订单 熊店 淘宝 人工