使用自定义元键和元值扩展 wc_get_orders()
Extend wc_get_orders() with a custom meta key and meta value
我正在尝试使用元键“order_referrer_id”获取所有商店订单,该值将是用户 ID,例如“1060”。
这是我到目前为止尝试过的方法:
$args = array(
'limit' => -1,
'status' => 'completed',
'meta_query' => array(
array(
'key' => 'order_referrer_id',
'value' => 1060,
'compare' => '='
),
),
'return' => 'ids',
);
$orders = wc_get_orders( $args );
出于某种原因,查询忽略了元查询和 returns 所有订单。
筛选店铺订单的正确方法是什么?
wc_get_orders
和 WC_Order_Query
提供了一种检索订单的标准方法,使用安全,不会因未来 WooCommerce 版本中的数据库更改而中断。
来源:wc_get_orders and WC_Order_Query
您可以使用 meta_key
、meta_value
和 meta_compare
,因此您得到:
$args = array(
'status' => 'completed', // Accepts a string: one of 'pending', 'processing', 'on-hold', 'completed', 'refunded, 'failed', 'cancelled', or a custom order status.
'meta_key' => 'order_referrer_id', // Postmeta key field
'meta_value' => 1060, // Postmeta value field
'meta_compare' => '=', // Possible values are ‘=’, ‘!=’, ‘>’, ‘>=’, ‘<‘, ‘<=’, ‘LIKE’, ‘NOT LIKE’, ‘IN’, ‘NOT IN’, ‘BETWEEN’, ‘NOT BETWEEN’, ‘EXISTS’ (only in WP >= 3.5), and ‘NOT EXISTS’ (also only in WP >= 3.5). Values ‘REGEXP’, ‘NOT REGEXP’ and ‘RLIKE’ were added in WordPress 3.7. Default value is ‘=’.
'return' => 'ids' // Accepts a string: 'ids' or 'objects'. Default: 'objects'.
);
$orders = wc_get_orders( $args );
// NOT empty
if ( ! empty ( $orders ) ) {
foreach ( $orders as $order ) {
echo '<p>ID = ' . $order . '</p>';
}
}
我正在尝试使用元键“order_referrer_id”获取所有商店订单,该值将是用户 ID,例如“1060”。
这是我到目前为止尝试过的方法:
$args = array(
'limit' => -1,
'status' => 'completed',
'meta_query' => array(
array(
'key' => 'order_referrer_id',
'value' => 1060,
'compare' => '='
),
),
'return' => 'ids',
);
$orders = wc_get_orders( $args );
出于某种原因,查询忽略了元查询和 returns 所有订单。
筛选店铺订单的正确方法是什么?
wc_get_orders
和 WC_Order_Query
提供了一种检索订单的标准方法,使用安全,不会因未来 WooCommerce 版本中的数据库更改而中断。
来源:wc_get_orders and WC_Order_Query
您可以使用 meta_key
、meta_value
和 meta_compare
,因此您得到:
$args = array(
'status' => 'completed', // Accepts a string: one of 'pending', 'processing', 'on-hold', 'completed', 'refunded, 'failed', 'cancelled', or a custom order status.
'meta_key' => 'order_referrer_id', // Postmeta key field
'meta_value' => 1060, // Postmeta value field
'meta_compare' => '=', // Possible values are ‘=’, ‘!=’, ‘>’, ‘>=’, ‘<‘, ‘<=’, ‘LIKE’, ‘NOT LIKE’, ‘IN’, ‘NOT IN’, ‘BETWEEN’, ‘NOT BETWEEN’, ‘EXISTS’ (only in WP >= 3.5), and ‘NOT EXISTS’ (also only in WP >= 3.5). Values ‘REGEXP’, ‘NOT REGEXP’ and ‘RLIKE’ were added in WordPress 3.7. Default value is ‘=’.
'return' => 'ids' // Accepts a string: 'ids' or 'objects'. Default: 'objects'.
);
$orders = wc_get_orders( $args );
// NOT empty
if ( ! empty ( $orders ) ) {
foreach ( $orders as $order ) {
echo '<p>ID = ' . $order . '</p>';
}
}