ホームページ >バックエンド開発 >PHPチュートリアル >顧客が WooCommerce で購入したかどうかを確認するにはどうすればよいですか?
顧客が WooCommerce で購入したかどうかを確認する方法
WooCommerce では、以前に購入した忠実な顧客にインセンティブを提供することは、一般的な習慣。このような戦略を効果的に実行するには、顧客が以前に購入を行ったかどうかを確認する必要があります。
購入履歴の確認
顧客の購入履歴を確認するには、WooCommerce が提供するサービスを提供します。 has_bought() と呼ばれる軽量で効率的な条件関数。この関数は、顧客データを分析して、顧客が以前に購入したかどうかを判断します。
この関数は、登録ユーザーとゲストの両方を処理します:
関数の実装
function has_bought( $value = 0 ) { if ( ! is_user_logged_in() && $value === 0 ) { return false; } global $wpdb; // Based on user ID (registered users) if ( is_numeric( $value) ) { $meta_key = '_customer_user'; $meta_value = $value == 0 ? (int) get_current_user_id() : (int) $value; } // Based on billing email (Guest users) else { $meta_key = '_billing_email'; $meta_value = sanitize_email( $value ); } $paid_order_statuses = array_map( 'esc_sql', wc_get_is_paid_statuses() ); $count = $wpdb->get_var( $wpdb->prepare(" SELECT COUNT(p.ID) FROM {$wpdb->prefix}posts AS p INNER JOIN {$wpdb->prefix}postmeta AS pm ON p.ID = pm.post_id WHERE p.post_status IN ( 'wc-" . implode( "','wc-", $paid_order_statuses ) . "' ) AND p.post_type LIKE 'shop_order' AND pm.meta_key = '%s' AND pm.meta_value = %s LIMIT 1 ", $meta_key, $meta_value ) ); // Return a boolean value based on orders count return $count > 0; }
使用法例
ログインしている顧客:
if( has_bought() ) echo '<p>You have already made a purchase</p>'; else echo '<p>Welcome, for your first purchase you will get a discount of 10%</p>';
請求先メールアドレスを持つゲスト:
$email = '[email protected]'; if( has_bought( $email ) ) echo '<p>customer have already made a purchase</p>'; else echo '<p>Customer with 0 purchases</p>'
以上が顧客が WooCommerce で購入したかどうかを確認するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。