Comment filtrer WP_Query pour les publications ayant une certaine méta-valeur, sans utiliser de requête de sélection personnalisée?
J'ai un type de message personnalisé avec méta-clé: "ouvert" et des options de méta-valeur: "oui" ou "non".
Je voudrais afficher les messages uniquement avec meta_value = yes, pour meta_key = "open".
function filter_where($where = '') {
$open = "yes";
//$where .= " AND post_date > '" . date('Y-m-d', strtotime('-2 days')) . "'";
return $where;
}
add_filter('posts_where', 'filter_where');
D'après votre libellé, je ne suis pas sûr si vous ne l'aviez pas essayé avec un argument de requête ou si cela n'avait pas fonctionné?
$the_query = new WP_Query(array( 'meta_key' => 'open', 'meta_value' => 'yes' ));
Paramètres de champ personnalisés dans Codex.
$querystr = "
SELECT wposts.*
FROM $wpdb->posts wposts, $wpdb->postmeta wpostmeta
WHERE wposts.ID = wpostmeta.post_id
AND wpostmeta.meta_key = 'custom-key'
AND wposts.post_type = 'page'
ORDER BY wpostmeta.meta_value DESC
";