Query multiple meta key values?

How to query for mutiple meta key values with the same key

$querystr = "  
            SELECT $wpdb->posts.* 
            FROM $wpdb->posts, $wpdb->postmeta
            WHERE $wpdb->posts.ID = $wpdb->postmeta.post_id 

            AND $wpdb->postmeta.meta_key = 'key1'   
            AND $wpdb->postmeta.meta_value = 'value1'
            // why doesn't this work?
            AND $wpdb->postmeta.meta_value = 'value2'

            AND $wpdb->posts.post_status = 'publish' 
            AND $wpdb->posts.post_type = 'post'
            ORDER BY $wpdb->posts.post_date DESC
                ";

next code

<?php 
$args = array(
    'meta_query' => array(
        array(
            'key' => 'key1',
            'value' => 'value1',
            'compare' => '='
        ),
// this array results in no return for both arrays
        array(
            'key' => 'key1',
            'value' => 'value2',
            'compare' => '='
        )
    )
);
$the_query  = new WP_Query( $args );
 ?>

                <?php /* Start the Loop */ ?>
<?php while ( $the_query->have_posts() ) : $the_query->the_post(); ?>

                    <?php get_template_part( 'content', get_post_format() ); ?>

                <?php endwhile; ?>

Related posts

Leave a Reply

4 comments

  1. I feel like there’s an AND/OR confusion going on here.

    The queries in the OP will only return posts which have both key1 = ‘value1’ AND key2 = ‘value2’. Most WP plugins (that I know of, anyway) do not store multiple values in postmeta, for the same post, using the same key.

    If what you want is really an OR (you want to get the posts where key1 = ‘value1’, as well as the posts where key1 = ‘value2’), then see @WhiskerSandwich’s answer, using ‘IN’ and an array of values for the value parameter.

    Alternatively, you can provide a relation parameter to `meta_query’:

    $args = array(
        'meta_query' => array(
            'relation' => 'OR',
            array(
                'key' => 'key1',
                'value' => 'value1',
                'compare' => '='
            ),
    
            array(
                'key' => 'key1',
                'value' => 'value2',
                'compare' => '='
            )
        )
    );
    

    Note that using OR as the relation for multiple meta queries using the same key is the functional equivalent of using IN and an array of values for a single one.

  2. I had the same problem where passing multiple arrays for the same key wasn’t working. Instead, just use one array, set ‘value’ to an array of values, and set ‘compare’ to IN:

    <?php
    
    $args = array(
        'meta_query' => array(
            array(
                'key' => 'key1',
                'value' => array('value1', 'value2'),
                'compare' => 'IN'
            ),
        )
    );
    $query = new WP_Query( $args );
    
    ?>
    
  3. You have to alias the postmeta table for the second value:

    $querystr = "  
            SELECT $wpdb->posts.* 
            FROM $wpdb->posts, $wpdb->postmeta, $wpdb->postmeta AS mt1
            WHERE $wpdb->posts.ID = $wpdb->postmeta.post_id 
            AND $wpdb->posts.ID = $wpdp->mt1.post_id
    
            AND $wpdb->postmeta.meta_key = 'key1'   
            AND $wpdb->postmeta.meta_value = 'value1'
            AND mt1.meta_key = 'key1'
            AND mt1.meta_value = 'value2'
    
            AND $wpdb->posts.post_status = 'publish' 
            AND $wpdb->posts.post_type = 'post'
            ORDER BY $wpdb->posts.post_date DESC
                ";
    

    You can also do this now since 3.1 with a meta_query:

    $args = array(
        'meta_query' => array(
            array(
                'key' => 'key1',
                'value' => 'value1',
                'compare' => '='
            ),
            array(
                'key' => 'key1',
                'value' => 'value2',
                'compare' => '='
            )
        )
    );
    $query = new WP_Query( $args );
    
  4. Key is key1 and values ‘value1’ and ‘value2’ tried it both text and numeric in a fresh install with twenty eleven. print_r( $the_query ); works output looks normal. Also tried key1 and key2 also doesn’t work. It works as soon as I limit it to to one array. Checked with different browsers.

    This however does work.

        <?php 
    $args = array(
        'meta_query' => array(
            array(
                'key' => 'wtf',
                'value' => '1',
                'compare' => '>='
            ),
    // this array results in no return for both arrays
            array(
                'key' => 'wtf',
                'value' => '2',
                'compare' => '<='
            )
        )
    );
    $the_query  = new WP_Query( $args );
    
     ?>