Früher konnte ich die Abfrageergebnisse nach 2 Kriterien sortieren ("Ergebnisse zuerst nach Status sortieren = unverkauft ASC, dann nach Datum DESC"):
add_action( 'pre_get_posts', 'my_get_posts' );
function my_get_posts( $query )
{
if (is_admin()){
return;
}
if (is_post_type_archive('objet')){
// Stock: sort by unsold first, then by date
$query->set('meta_key', 'wpcf-object-sold-status' );
$query->set('orderby', 'meta_value date');
$query->set('order', 'ASC DESC' );
}
return $query;
}
Aber jetzt ändert sich die Reihenfolge der Ergebnisse nicht mehr. Ich habe keine Ahnung, warum es nicht mehr funktioniert. Vielleicht das Update von Wordpress 3 auf 4?
Wie Milo sagte:
$query->set('meta_key', 'wpcf-object-sold-status' );
$query->set('orderby', array('meta_value' => 'ASC', 'date' => 'DESC'));
// $query->set('order', 'ASC DESC' ); // not needed
Relevanter Link: https://make.wordpress.org/core/2014/08/29/a-more-powerful-order-by-in-wordpress-4-0/