使用meta_query對WP_Query進行「orderby」(ASC和DESC)篩選的方法
<p>我正在嘗試使用自訂元資料'like_count_on_post'按'DESC'篩選帖子,然後收集所有空的'like_count_on_post'和'dislike_count_on_post',最後按'dislike_count_on_post'的'ASC'排序,但我只能得到按降序排列的讚,或者如果我刪除:</p>
<blockquote>
<p>'custom_field_value' => 'DESC'</p>
</blockquote>
<p>我可以得到按踩升序排列,但不能同時得到兩者。 </p>
<p>查詢參數代碼:</p>
<pre class="brush:php;toolbar:false;">$args = array(
'post_status' => 'publish',
'post_type' => 'sveikinimai',
'meta_query' => array(
"relation" => "and",
'likes' => array(
"relation" => "or",
'custom_field_value' => array(
'key' => '_like_count_on_post_',
),
'custom_field' => array(
'key' => '_like_count_on_post_',
'compare' => 'NOT EXISTS',
),
),
'dislikes' => array(
"relation" => "or",
'custom_field_value_2' => array(
'key' => '_dislike_count_on_post_',
),
'custom_field_2' => array(
'key' => '_dislike_count_on_post_',
'compare' => 'NOT EXISTS',
),
),
),
'orderby' => array(
'custom_field_value' => 'DESC',
'custom_field_value_2' => 'ASC'
),
'posts_per_page' => 20,
'paged' => $paged,
);</pre>
<p>更新,如果你想要過濾掉不存在的元資料字段,這是代碼:</p>
<pre class="brush:php;toolbar:false;">$args = array(
'post_status' => 'publish',
'post_type' => 'sveikinimai',
'meta_query' => array(
"relation" => "and",
'custom_field_value' => array(
'key' => '_like_count_on_post_',
),
'custom_field_value_2' => array(
'key' => '_dislike_count_on_post_',
),
),
'orderby' => array(
'custom_field_value' => 'DESC',
'custom_field_value_2' => 'ASC'
),
'posts_per_page' => 20,
'paged' => $paged,
);</pre></p>