Ich versuche, den Artikel-Meta-Wert aus den Bestellungen von Woocommerce zu extrahieren, indem Sie Folgendes verwenden:
$data = wc_get_order_item_meta( $item, '_tmcartepo_data', true );
Ich kann jedoch keinen Weg finden, um order_item_id als ersten Parameter zu erhalten (mithilfe von 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;
}
Und ich meine diese order item_id (1 und 2)
Order_item_id in der Datenbank - Bild
Wie kann ich das anlegen?
Vielen Dank.
2018 Update:
- Klärung der Antwort mit 2 möglichen Fällen
- Kompatibilität für Woocommerce 3+ wurde hinzugefügt
So kann es 2 Fälle geben:
1) Produkt-Metadaten abrufen (nicht in Auftragspositions-Metadaten festgelegt):
Sie müssen die Produkt-ID für einen WC_Order
in der foreach-Schleife abrufen. Um Metadaten für dieses Produkt zu erhalten, verwenden Sie get_post_meta()
function (aber NICHT wc_get_order_item_meta()
).
Also hier ist dein Code:
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) Metadaten der Auftragsposition abrufen (benutzerdefinierter Feldwert):
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;
}
}
Wenn die benutzerdefinierten Felddaten ein Array sind, können Sie in einer foreach-Schleife auf die Daten zugreifen:
// Iterating in an array of keys/values
foreach( $custom_field as $key => $value ){
echo '<p>key: '.$key.' | value: '.$value.'</p>';
}
Der gesamte Code wurde getestet und funktioniert.
Referenz bezogen auf Daten in Bestellungen:
Bei der Durchführung von foreach auf $order->get_items()
ist deren Schlüssel eigentlich die Bestellposten-ID. So:
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...
}
Ich bin spät dran, aber mit dem gleichen Punkt mit dem TM Extra Product Options Plugin zu arbeiten, denke ich, dass dies Ihre Frage beantwortet:
$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;
}
Getestet und funktioniert in meinem Fall.
Eine einfache Möglichkeit, Bestellartikel aus der Datenbank abzurufen.
/**
* @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;
}
foreach ( $order->get_items() as $key => $item ) {
$data = wc_get_order_item_meta( $key, '_tmcartepo_data' );
...
Diese Lösung hat sich für mich gelohnt. Ändern Sie "_tmcartepo_data" für Ihren meta_key.
Verwenden Sie diese <pre><?php print_r($items); ?></pre>
, um den gesamten Inhalt des $ items-Arrays/Objekts zu überprüfen.