web-dev-qa-db-ja.com

注文アイテムIDを取得して製品のメタデータを取得する方法は?

私は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-イメージ

どうすればそれを着ることができますか?

ありがとう。

13
camelot

2018アップデート:

  • 2つの可能なケースで答えを明確にする
  • Woocommerce 3+の互換性を追加

したがって、2つのケースがあります:

1)製品メタデータの取得(オーダーアイテムメタデータに設定されていない):

_WC_Order_のforeachループで製品IDを取得し、使用するこの製品のメタデータを取得する必要がありますget_post_meta()function(but NOTwc_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>';
} 
_

すべてのコードがテストされ、動作します。

注文のデータに関連する参照:

20
LoicTheAztec

$order->get_items()でforeachを実行する場合、それらのキーは実際にはオーダーラインIDです。そう:

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

パーティーに遅刻しましたが、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;
}

私の場合はテスト済みで動作します。

2
jgangso

データベースから注文アイテムを取得する簡単な方法。

/**
 * @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;
}
0
Mostafa Soufi
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...

このソリューションは私にとって価値がありました。meta_keyの「_tmcartepo_data」を変更します。

0

この<pre><?php print_r($items); ?></pre>を使用して、$ items配列/オブジェクトのすべての内容を確認します。

0
Cagy79