Obtener publicaciones por valor meta

17

Me gustaría enumerar todas las publicaciones que tienen una clave de cp_annonceur con el valor professionnel .

    
pregunta Beginner 11.05.2014 - 21:56

4 respuestas

36

Lo que estás pidiendo es un meta_query

$args = array(
   'meta_query' => array(
       array(
           'key' => 'cp_annonceur',
           'value' => 'professionnel',
           'compare' => '=',
       )
   )
);
$query = new WP_Query($args);

Toda la información que necesita está en el Codex .

    
respondido por el s_ha_dum 11.05.2014 - 22:05
7

Hay dos formas de hacerlo:

  1. Interceptar la consulta principal en pre_get_posts :

    add_action( 'pre_get_posts', function( $query )
    {
        // only handle the main query
        if ( ! $query->is_main_query() )
            return;
    
        $query->set( 'meta_key',   'cp_annonceur' );
        $query->set( 'meta_value', 'professionnel' );
    } );
    
  2. Añadir una consulta adicional

    $second_loop = get_posts( array(
        'meta_key'   => 'cp_annonceur',
        'meta_value' => 'professionnel',
    ) );
    
respondido por el kaiser 11.05.2014 - 22:08
4

Usé la selección personalizada (podría ser un mejor rendimiento)

$posts = $wpdb->get_results("SELECT * FROM $wpdb->postmeta
WHERE meta_key = 'cp_annonceur' AND  meta_value = 'professionnel' LIMIT 1", ARRAY_A);

Inspirado en enlace

    
respondido por el michalzuber 28.01.2016 - 15:40
0

Podemos obtener el resultado deseado con la consulta Meta de WordPress:

// the meta_key 'diplay_on_homepage' with the meta_value 'true'
$cc_args = array(
    'posts_per_page'   => -1,
    'post_type'        => 'post',
    'meta_key'         => 'cp_annonceur',
    'meta_value'       => 'professionnel'
);
$cc_query = new WP_Query( $cc_args );

Para obtener una guía más detallada con respecto a la meta consulta, siga este blog: enlace

    
respondido por el Jitendra Damor 04.10.2017 - 07:46

Lea otras preguntas en las etiquetas