首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Wordpress查询- meta_value_num和date的顺序

Wordpress查询- meta_value_num和date的顺序
EN

Stack Overflow用户
提问于 2014-04-08 08:10:37
回答 1查看 3.1K关注 0票数 1

我现在有点被wp_query的订单卡住了。

我想首先通过meta_value_num对查询进行排序(这非常完美),并在日期之前作为回退。但在我的查询中,与meta_value_num相比,日期似乎占主导地位。

因此,它按日期对我的所有帖子进行排序,然后使用meta_num_value命令,而不是反之亦然。

你知道怎么做吗?

代码语言:javascript
运行
复制
$args = array(
    'post_type' => 'anbieter',
    'showposts' => -1,
    'order' => 'DESC',
    'orderby' => 'meta_value_num date',
    'meta_key' => 'rating'
);

我发现有那么多线程要按两个自定义字段进行排序,而不是按“普通post字段”和“自定义字段”排序。

打招呼,

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-06-25 08:49:42

不久前我找到了一个解决办法,就是这个。将此添加到您的functions.php中:

代码语言:javascript
运行
复制
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;
}

然后用您的查询执行以下操作:

代码语言:javascript
运行
复制
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);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22931214

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档