WC_Admin_Report 按产品名称生成订单报告

Generate order report by product name by WC_Admin_Report

我想生成包含特定名称的订购产品的订单报告。

例如我想要标题为"toy"的产品的销售报告,其中的产品包括"car toy"、"tools toy"、"bike toy"...等等

我想使用 Woocommerce WC_Admin_Report class 来生成报告,但我无法让它工作。

include_once($woocommerce->plugin_path().'/includes/admin/reports/class-wc-admin-report.php');
$wc_report = new WC_Admin_Report();

$where_meta[] = array(
            'type' => 'order_item_meta',
            'meta_key' => '_product_name',
            'operator' => 'LIKE',
            'meta_value' => 'shirt'
        );

$sold_products = $wc_report->get_order_report_data(array(
        'data' => array(
            '_product_id' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => '',
                'name' => 'product_id'
            ),
            '_qty' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'quantity'
            ),
            '_line_subtotal' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'gross'
            ),
            '_line_total' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'gross_after_discount'
            )
        ),
        'query_type' => 'get_results',

        'where_meta' => $where_meta,

        'limit' => 20,

        'order_status' => array( 'completed', 'processing')
    ));

where_meta 只查找产品名称在 woocommerce_order_items table 中的 woocommerce_order_itemmeta table,如何通过 woocommerce_order_items 还有吗?是这样的吗?

 $where_meta[] = array(
                'type' => 'order_item',
                'meta_key' => 'order_item_name',
                'operator' => 'LIKE',
                'meta_value' => 'toy'
            );

你可以为你的 $where_meta 这样做。

$products = new WP_Query( array( 
    's'             => 'shirt',
    'post_type'     => 'product',
    'fields'        => 'ids'
) );

$product_ids = $products->posts;

$where_meta = array (
    'relation' => 'OR',
    array(
        'type'       => 'order_item_meta',
        'meta_key'   => array( '_product_id', '_variation_id' ),
        'meta_value' => $product_ids,
        'operator'   => 'IN',
    ),
);

另外,你也可以这样做。更方便。
使用 where 而不是 where_meta.

$where => array(
    array(
        'key'      => 'order_items.order_item_name',
        'value'    => '%shirt%',
        'operator' => 'LIKE',
    ),
),

您还需要在 init 上调用它。所以它应该看起来像这样:

add_action('init', 'reports');

function reports() {


    include_once(WC()->plugin_path().'/includes/admin/reports/class-wc-admin-report.php');
    $wc_report = new WC_Admin_Report();

    $sold_products = $wc_report->get_order_report_data( array(
        'data' => array(
            '_product_id' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => '',
                'name' => 'product_id'
            ),
            '_qty' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'quantity'
            ),
            '_line_subtotal' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'gross'
            ),
            '_line_total' => array(
                'type' => 'order_item_meta',
                'order_item_type' => 'line_item',
                'function' => 'SUM',
                'name' => 'gross_after_discount'
            )
        ),
        'where' => array(
            array(
                'key'      => 'order_items.order_item_name',
                'value'    => '%shirt%',
                'operator' => 'LIKE',
            ),
        ),

        'group_by'     => 'order_item_name',

        'query_type' => 'get_results',

        'limit' => 20,

        'order_status' => array( 'completed', 'processing' ),
    ) );

    print_r($sold_products);    
}

别忘了'group_by'

    /* sample output of print_r($sold_products);
    Array
    (
        [0] => stdClass Object
            (
                [product_id] => 70
                [quantity] => 3
                [gross] => 36
                [gross_after_discount] => 36
            )

        [1] => stdClass Object
            (
                [product_id] => 53
                [quantity] => 4
                [gross] => 140
                [gross_after_discount] => 140
            )

        [2] => stdClass Object
            (
                [product_id] => 50
                [quantity] => 1
                [gross] => 10
                [gross_after_discount] => 10
            )

    )

    */