Woocommerce: функция обновления всех продуктов - PullRequest
2 голосов
/ 03 мая 2019

У меня проблема с моими продуктами Woocommerce. Эта проблема устраняется, если я просто обновляю продукт (редактирую продукт и нажимаю кнопку «Обновить») без каких-либо изменений.

На моем сайте около 2000 товаров, и я думаю сделать это, используя функцию из моего файла function.php.

Должно быть что-то вроде этого, мне просто нужна строка для обновления продукта.

function update_all_products(){

    // getting all products
    $products = get_posts( $args );

    // Going through all products
    foreach ( $products as $key => $value ) {

        // the product ID
        $product_id = $value->ID;

        // update product
        update_post_meta...(NEED HELP HERE)...

   } //..end foreach
}

// fire the function
update_all_products();

1 Ответ

2 голосов
/ 03 мая 2019

Попробуйте следующее, чтобы каждый раз обновлять ваши продукты на 200, чтобы избежать проблем (если у вас есть и переменные продукты, аргумент post_type должен быть product & product_variation) :

 add_action( 'woocommerce_loaded', 'update_products_by_x' );
function update_products_by_x(){
    $limit = 200;

    // getting all products
    $products_ids = get_posts( array(
        'post_type'        => 'product', // or ['product','product_variation'],
        'numberposts'      => $limit,
        'post_status'      => 'publish',
        'fields'           => 'ids',
        'meta_query'       => array( array(
            'key'     => '_sync_updated',
            'compare' => 'NOT EXISTS',
        ) )
    ) );

    // Loop through product Ids
    foreach ( $products_ids as $product_id ) {

        // Get the WC_Product object
        $product = wc_get_product($product_id);

        // Mark product as updated
        $product->update_meta_data( '_sync_updated', true );

        $product->save();
    }
}

Код помещается в файл function.php вашей активной дочерней темы (или активной темы).Протестировано и работает.

Каждый раз, когда вы просматриваете страницу своего сайта, функция будет активирована.обработка продуктов на 200 просто более безопасна и позволит избежать тайм-аута или ошибок.

Например, вы можете увеличить это число до 500, установив для $limit значение 500

...