sql >> Database teknologi >  >> RDS >> Mysql

Få produkt min_pris af sku

For at filtrere forespørgslen via post_status vi skal først lede efter værdien i den korrekte tabel, som er wp posts-tabellen, vi kan gøre det ved at opdatere vores SQL-forespørgsel ved hjælp af JOIN-sætningen og matche de korrelerende værdier i flere tabeller, i dette tilfælde matcher vi produkt-id i wp.posts tabel med den i wp.postmeta tabel.

Tabellerne matcher vi ved hjælp af JOIN-sætningen:

  • wp.posts $wpdb->posts
  • wp.postmeta $wpdb->wc_product_meta_lookup

Nedenfor er en opdateret funktion:

function get_product_min_price_by_sku( $sku ) {
    global $wpdb;

    $min_price = $wpdb->get_var(
        $wpdb->prepare(
            "
            SELECT MIN(lookup.min_price) 
            FROM {$wpdb->wc_product_meta_lookup} AS lookup
            INNER JOIN {$wpdb->posts} AS posts ON lookup.product_id = posts.id
            WHERE
            posts.post_type IN ( 'product', 'product_variation' )
            AND posts.post_status = 'publish'
            AND lookup.sku = '%s'
            LIMIT 1
            "
        , $sku)
    );

    return $min_price;
}



  1. Kontroller, om værdien eksisterer, før du indsætter i MySQL DB i et PHP-script

  2. oracle replace view under forespørgsel

  3. Cross database trigger i Mysql

  4. Sådan fungerer SHOW CHARACTER SET i MariaDB