17

批量导入/删除后如何更新 WordPress 分类(类别/标签)的计数字段?

相关问题:

WordPress › 支持 » 导入后修复评论和类别计数 http://wordpress.org/support/topic/fix-comment-and-category-counts-after-import

4

4 回答 4

69

This SQL helps:

UPDATE wp_term_taxonomy SET count = (
SELECT COUNT(*) FROM wp_term_relationships rel 
    LEFT JOIN wp_posts po ON (po.ID = rel.object_id) 
    WHERE 
        rel.term_taxonomy_id = wp_term_taxonomy.term_taxonomy_id 
        AND 
        wp_term_taxonomy.taxonomy NOT IN ('link_category')
        AND 
        po.post_status IN ('publish', 'future')
)
于 2013-09-07T03:03:35.673 回答
18

一种更符合 WordPress 的方式是使用wp_update_term_count_nowhttps://developer.wordpress.org/reference/functions/get_terms/

例子:

$update_taxonomy = 'my_taxonomy';
$get_terms_args = array(
        'taxonomy' => $update_taxonomy,
        'fields' => 'ids',
        'hide_empty' => false,
        );

$update_terms = get_terms($get_terms_args);
wp_update_term_count_now($update_terms, $update_taxonomy);
于 2016-05-16T21:21:07.723 回答
6

@kaorukobo 的回答效果很好。但是,我需要更多的自定义来自动更新 CPT 的所有术语......特别是带有几个自定义分类法的 WooCommerce 产品 CPT......

以下更新了产品 CPT 的所有分类。

UPDATE wp_term_taxonomy tt
    SET count =
    (SELECT count(p.ID) FROM  wp_term_relationships tr
    LEFT JOIN wp_posts p
    ON (p.ID = tr.object_id AND p.post_type = 'product' AND p.post_status = 'publish')
    WHERE tr.term_taxonomy_id = tt.term_taxonomy_id
)
于 2014-11-28T22:09:43.943 回答
4

在我看来,最好的方法是使用WP-CLI。有一个命令:

$ wp term recount category

在这里找到文档:https ://developer.wordpress.org/cli/commands/term/recount/

于 2020-12-09T14:48:38.060 回答