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
)
)
*/
我想生成包含特定名称的订购产品的订单报告。
例如我想要标题为"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
)
)
*/