Menyemak Sejarah Pembelian dalam WooCommerce
Masalah:
Anda ingin mencipta pemalam WooCommerce yang menawarkan tawaran eksklusif kepada pelanggan dengan sejarah pembelian. Cabarannya ialah menentukan sama ada pengguna telah membuat pembelian pada masa lalu.
Penyelesaian:
Menyemak Pembelian Lalu untuk Pelanggan
Untuk menyemak sama ada pelanggan telah membuat sebarang pembelian lalu, anda boleh memanfaatkan fungsi tersuai yang mengendalikan pengguna berdaftar dan pengguna tetamu dengan lancar:
function has_bought( $value = 0 ) { // Handling for registered users if ( is_numeric( $value) ) { // Use current user ID if not provided $meta_key = '_customer_user'; $meta_value = $value == 0 ? (int) get_current_user_id() : (int) $value; } // Handling for guest users else { $meta_key = '_billing_email'; $meta_value = sanitize_email( $value ); } global $wpdb; // Determine if any paid orders exist $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 true if at least one paid order exists return $count > 0; }
Contoh Penggunaan:
Contoh 1: Semak pembelian oleh pelanggan yang sedang log masuk
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>';
Contoh 2: Semak pembelian menggunakan ID pengguna tertentu
// Define the user ID $user_id = 85; if( has_bought( $user_id ) ) echo '<p>customer have already made a purchase</p>'; else echo '<p>Customer with 0 purchases</p>';
Contoh 3: Semak pembelian melalui e-mel pengebilan pengguna tetamu
// Define the billing email (string) $email = '[email protected]'; if( has_bought( $email ) ) echo '<p>customer have already made a purchase</p>'; else echo '<p>Customer with 0 purchases</p>'
Atas ialah kandungan terperinci Bagaimana untuk Semak sama ada Pengguna WooCommerce Telah Membuat Pembelian Lalu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!