如何获取订单项目ID以获取某些产品元数据?

22

我正在尝试使用以下方法从Woocommerce订单中提取项目元值:

$data = wc_get_order_item_meta( $item, '_tmcartepo_data', true );

然而,我无法找到一种方法来将 order_item_id 作为第一个参数(使用 get_items)。

global $woocommerce, $post, $wpdb;
$order = new WC_Order($post->ID);
$items = $order->get_items(); 

foreach ( $items as $item ) {
    $item_id = $item['order_item_id']; //???
    $data = wc_get_order_item_meta( $item_id, '_tmcartepo_data', true );
    $a = $data[0]['value'];
    $b = $data[1]['value'];
    echo $a;
    echo $b;
}

我的意思是这个订单的item_id(1和2)

数据库中的Order_item_id - 图片

我该如何做到这一点?

谢谢。


请描述此操作何时触发 - 例如:woocommerce_checkout_create_order 钩子在任何数据库交互之前触发,因此无法通过 $order->get_items() 访问订单项目。 - Amit Rahav
6个回答

30

2018年更新:

  • 澄清答案中的两种可能情况
  • 添加了与WooCommerce 3+兼容性

因此有两种情况:

1)获取产品元数据(未在订单项目元数据中设置):

您需要在WC_Order的foreach循环中获取产品ID,并使用get_post_meta()函数获取此产品的一些元数据(但不是wc_get_order_item_meta()

所以这是你的代码:

global $post;
$order = wc_get_order( $post->ID );
$items = $order->get_items(); 

foreach ( $order->get_items() => $item ) {

    // Compatibility for woocommerce 3+
    $product_id = version_compare( WC_VERSION, '3.0', '<' ) ? $item['product_id'] : $item->get_product_id();

    // Here you get your data
    $custom_field = get_post_meta( $product_id, '_tmcartepo_data', true); 

    // To test data output (uncomment the line below)
    // print_r($custom_field);

    // If it is an array of values
    if( is_array( $custom_field ) ){
        echo implode( '<br>', $custom_field ); // one value displayed by line 
    } 
    // just one value (a string)
    else {
        echo $custom_field;
    }
}

2) 获取订单商品元数据(自定义字段的值):


global $post;
$order = wc_get_order( $post->ID );
$items = $order->get_items(); 

foreach ( $order->get_items() as $item_id => $item ) {

    // Here you get your data
    $custom_field = wc_get_order_item_meta( $item_id, '_tmcartepo_data', true ); 

    // To test data output (uncomment the line below)
    // print_r($custom_field);

    // If it is an array of values
    if( is_array( $custom_field ) ){
        echo implode( '<br>', $custom_field ); // one value displayed by line 
    } 
    // just one value (a string)
    else {
        echo $custom_field;
    }
}
如果自定义字段数据是一个数组,您可以在 foreach 循环中访问数据:
// Iterating in an array of keys/values
foreach( $custom_field as $key => $value ){
    echo '<p>key: '.$key.' | value: '.$value.'</p>';
} 

所有的代码都经过测试并且可用。

有关订单中数据的参考资料:


你好,感谢您的回复。然而,$item['product_id'] 只能获取到订单号,对我并没有帮助。您可以看到我上面的图片(http://i.stack.imgur.com/8OJ7U.jpg)。我只能在 meta_value 列中获取产品 ID(数字 90),但我需要的是 order_item_id 中的数字(1 或 2),这样我才能获取 _tmcartepo_data meta_key 的值。有什么想法吗? - camelot
我目前在调用get_items()(WP 4.6.1和WC 2.6.4)时遇到了“在布尔值上调用成员函数get_items()”错误。我正在努力找出原因,但似乎你指引了我正确的方向。 - camelot

6
在使用$order->get_items()进行foreach循环时,它们的键实际上是订单行ID。因此:
foreach ( $order->get_items() as $key => $item ) {
    $data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
    ...
}

2
晚了一步,但与TM Extra Product Options插件的相同点是,在此问题上进行工作时,我认为以下内容可以回答您的问题:
$order = wc_get_order( $post->ID );
$items = $order->get_items();


foreach( $items as $item ){
    $data = unserialize($item['item_meta']['_tmcartepo_data'][0]);
    $a = $data[0]['value'];
    $b = $data[1]['value'];
    echo $a;
    echo $b;
}

已测试,适用于我的情况。


0
使用这个<pre><?php print_r($items); ?></pre>来检查$items数组/对象的所有内容。

0
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...

这个解决方案对我很有价值,将“_tmcartepo_data”更改为您的meta_key。


0

从数据库中获取订单商品的简单方法;

/**
 * @param $order_id
 *
 * @return array|null|object
 */
function get_order_items( $order_id ) {
    global $wpdb, $table_prefix;

    $items     = $wpdb->get_results( "SELECT * FROM `{$table_prefix}woocommerce_order_items` WHERE `order_id` = {$order_id}" );
    $item_name = array();

    foreach ( $items as $item ) {
        $item_name[] = $item->order_item_name;
    }

    return $item_name;
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接