web-dev-qa-db-de.com

Filtern Sie WP_Query nach Posts mit einem bestimmten Meta-Wert

Wie filtere ich WP_Query nach Posts mit einem bestimmten Meta-Wert, ohne eine benutzerdefinierte Auswahlabfrage zu verwenden?

Ich habe einen benutzerdefinierten Posttyp mit Metaschlüssel: "Öffnen" und Meta-Wert-Optionen: "Ja" oder "Nein".

Ich möchte Beiträge nur mit meta_value = yes, für meta_key = "open" anzeigen.

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');
7
Henk Jan

Ich bin mir nach Ihrer Formulierung nicht sicher, ob Sie es nicht mit einem Abfrageargument versucht haben oder ob es nicht funktioniert hat.

$the_query = new WP_Query(array( 'meta_key' => 'open', 'meta_value' => 'yes' ));

Benutzerdefinierte Feldparameter im Codex.

10
Rarst
 $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
    ";
1
Pragya