Verifique se o valor da chave meta já existe

2

Digamos que eu tenha poucas postagens com meta-chave "videoid". O valor dessa meta-chave é diferente para cada postagem (e tem que ser diferente). Ao adicionar uma nova postagem, como posso verificar se o videoid com esse valor exato já existe para algumas postagens mais antigas? Eu usei isso como uma referência para adicionar meta box personalizada à área administrativa do WP: enlace

    
por SomeoneS 04.11.2013 / 13:10

4 respostas

7

Basta fazer uma consulta com WP_Query usando o Parâmetro de campos personalizados - meta_query para procurar postagens com o meta key e o valor - código exemplar:

 // args to query for your key
 $args = array(
   'post_type' => 'your_post_type',
   'meta_query' => array(
       array(
           'key' => 'videoid',
           'value' => '111'
       )
   ),
   'fields' => 'ids'
 );
 // perform the query
 $vid_query = new WP_Query( $args );

 $vid_ids = $vid_query->posts;

 // do something if the meta-key-value-pair exists in another post
 if ( ! empty( $vid_ids ) ) {
     // do your stuff
 }

Não há necessidade de usar query_post() - consulte: Quando você deve usar WP_Query vs query_posts () vs get_posts ()? . Se você precisar de uma matriz completa de objetos de postagem, não apenas os IDs, remova 'fields' => 'ids' .

    
por Nicolai 04.11.2013 / 14:16
2

A resposta da ialocin afirma incorretamente que o wp_query armazenado como uma variável apenas cuspia uma matriz de IDs. Em vez disso, ele fornece todo o objeto WP_Query, portanto, é necessário usar - > posts para obter essa matriz de IDs de postagem.

// args to query for your key
 $args = array(
   'post_type' => 'YOUR_POST_TYPE',
   'meta_query' => array(
       array(
           'key' => 'YOUR_META_FIELD_NAME',
           'value' => '111'
       )
   ),
   'fields' => 'ids'
 );
 // perform the query
 $query = new WP_Query( $args );
 $duplicates = $query->posts;

 // do something if the key-value-pair exists in another post
 if ( ! empty( $duplicates ) ) {
     // do your stuff
 }
    
por jetlej 19.10.2014 / 03:55
1

Ou envolva-o em uma função:

function meta_value_exists($your_meta_value) {
    $args = array(
        'post_type'   => 'YOUR_POST_TYPE',
        'post_status' => 'publish',
        'numberposts' => 1,
        'meta_key'     => 'your_meta_field',
        'meta_value'   => $your_meta_value,
    );
    $current_post = get_posts($args);
    if( $current_post ) {
        return true;
    } else {
        return false;
    }
}

Então você pode verificar seu valor meta:

$video_id = 1234;
if(meta_value_exists($video_id){
   // do something if exists
} else {
   // do something if not exists
}
    
por cscheltinga 24.08.2016 / 19:09
0

Encontrou:

$args = array(
    'meta_query' => array(
        array(
            'key' => 'videoid',
            'value' => $_POST['videoid']
        )
    )
);

$videoQuery = new WP_Query( $args ); 

if ( $videoQuery->have_posts() ) :
    while ( $videoQuery->have_posts() ) : 
            $videoQuery->the_post(); ?>
    echo "<h3 class='post-title'>" . the_title() . "</h3>";
    endwhile; 
    endif;
    
por SomeoneS 04.11.2013 / 14:00