Я пытаюсь извлечь мета-значение элемента из заказов 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 в базе данных - Изображение

Как я могу это надеть?

Спасибо.

16
camelot 8 Сен 2016 в 15:23

5 ответов

Простой способ получить позиции заказа из базы данных;

/**
 * @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 18 Ноя 2017 в 17:33

При выполнении foreach на $order->get_items() их ключ фактически является идентификатором строки заказа. Так:

foreach ( $order->get_items() as $key => $item ) {
    $data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
    ...
}
6
Berend 20 Фев 2017 в 14:11

Поздно к вечеринке, но, работая с той же точкой с плагином 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 6 Окт 2016 в 22:49
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...

Мне это решение стоило, замените "_tmcartepo_data" на свой meta_key.

0
Luis Vergh1l Miguel 8 Авг 2017 в 09:29

Используйте этот <pre><?php print_r($items); ?></pre> для проверки всего содержимого массива / объекта $ items.

0
Cagy79 8 Сен 2016 в 12:25