首页 > 解决方案 > 在 WooCommerce 中获取和显示产品 On Sale 计数

问题描述

通过执行 SQL 查询(似乎无法正常工作)计算有多少产品在售(它计算有多少产品有折扣价),我的目标是使用钩。该消息应包含计数(有多少产品在售)。

期望的示例输出:“正在寻找优惠?我们目前有 XX 产品在售!”

关于为什么这不起作用的任何想法或见解?这是我的代码:

function get_onsale_products_count() {
    global $wpdb;

    // SQL query for counting products that are on sale
    $result = $wpdb->get_col( "
        SELECT COUNT(p.ID)
        FROM {$wpdb->prefix}posts as p
        INNER JOIN {$wpdb->prefix}postmeta as pm ON p.ID = pm.post_id
        WHERE p.post_type LIKE '%product%'
        AND p.post_status LIKE 'publish'
        AND pm.meta_key LIKE '_stock_status'
        AND pm.meta_value LIKE '_on_sale'
    " );

    return reset($result);
}

add_action('woocommerce_before_single_product_summary', 'get_onsale_products_count');
$count = get_onsale_products_count();
$great_deal = sprintf( __( 'Want to make a good deal? We\'ve got %s products on sale!' ), $count );
echo '<span class="great-deal">'.$great_deal.'</span>';

标签: phpwordpresswoocommerceproductdiscount

解决方案


库存状态与“特价”产品无关,_on_sale元值不存在,这就是您的 SQL 查询不起作用的原因。

特价产品有一个明确的“销售价格”,所以请尝试:

function get_onsale_products_count() {
    global $wpdb;

    // SQL query for counting products that are on sale
    return $wpdb->get_var( "
        SELECT COUNT(p.ID)
        FROM {$wpdb->prefix}posts as p
        INNER JOIN {$wpdb->prefix}postmeta as pm ON p.ID = pm.post_id
        WHERE p.post_type LIKE '%product%'
        AND p.post_status = 'publish'
        AND pm.meta_key = '_sale_price'
        AND pm.meta_value != ''
    " );
}

add_action( 'woocommerce_before_single_product_summary', 'display_onsale_products_count_message', 3 );
function display_onsale_products_count_message(){
    echo '<span class="great-deal">' . sprintf( __( "Want to make a good deal? We've got %s products on sale!" ), 
    get_onsale_products_count() ) . '</span>';
}

代码位于您的活动子主题(或活动主题)的 function.php 文件中。测试和工作。


推荐阅读