我现在有点被wp_query的订单卡住了。
我想首先通过meta_value_num对查询进行排序(这非常完美),并在日期之前作为回退。但在我的查询中,与meta_value_num相比,日期似乎占主导地位。
因此,它按日期对我的所有帖子进行排序,然后使用meta_num_value命令,而不是反之亦然。
你知道怎么做吗?
$args = array(
'post_type' => 'anbieter',
'showposts' => -1,
'order' => 'DESC',
'orderby' => 'meta_value_num date',
'meta_key' => 'rating'
);我发现有那么多线程要按两个自定义字段进行排序,而不是按“普通post字段”和“自定义字段”排序。
打招呼,
发布于 2014-06-25 08:49:42
不久前我找到了一个解决办法,就是这个。将此添加到您的functions.php中:
function wdw_query_orderby_postmeta_date( $orderby ){
$new_orderby = str_replace( "wp_postmeta.meta_value", "STR_TO_DATE(wp_postmeta.meta_value, '%d-%m-%Y')", $orderby );
return $new_orderby;
}然后用您的查询执行以下操作:
add_filter( 'posts_orderby', 'wdw_query_orderby_postmeta_date', 10, 1);
$args = array(
'post_type' => 'anbieter',
'showposts' => -1,
'order' => 'DESC',
'orderby' => 'meta_value',
'meta_key' => 'rating'
);
remove_filter( 'posts_orderby', 'wdw_query_orderby_postmeta_date', 10, 1);https://stackoverflow.com/questions/22931214
复制相似问题