2017-06-12 422 views
0

我試圖與過濾運行自定義循環的自定義文章類型由一些meta_keyvalueWordPress的定製環路濾波器

現在簡單的meta值正常工作,但在這裏我與挑戰低於某種序列化數據(嵌套)。

我對元框使用wpalchemymeta_key的職位類型是_event_metavalue是如下

a:9:{s:19:"ac_event_operations";a:1:{i:0;s:8:"Training";}s:18:"ac_event_positions";a:1:{i:0;s:10:"Supervisor";}s:18:"ac_event_employees";a:1:{i:0;s:2:"15";}s:13:"ac_event_date";s:10:"2017-06-15";s:19:"ac_event_start_time";s:5:"06:30";s:17:"ac_event_end_time";s:5:"07:00";s:14:"ac_event_place";s:6:"Office";s:18:"ac_event_organizer";s:4:"Jack";s:16:"ac_event_contact";s:4:"Rose";} 

我基於ac_event_operationsac_event_positionsac_event_employees

所以我想篩選All Events,面臨的挑戰是讓事件與值濾波從meta_keys以上。這是我使用的查詢,但當然,它沒有給出任何結果。

global $event_mb; 
$meta = get_post_meta(get_the_ID(), $event_mb->get_the_id(), TRUE); 

$paged = (get_query_var('paged')) ? get_query_var('paged') : 1; 
$args  = [ 
    'post_type'  => 'event', 
    'posts_per_page' => get_option('posts_per_page'), 
    'paged'   => $paged, 
    'meta_query'  => [ 
     'meta_key' => '_event_meta', 
     'value' => '%ac_event_employees%', 
     'compare' => 'LIKE' 
    ], 

]; 
$temp  = $wp_query; 
$wp_query = NULL; 
$wp_query = new WP_Query($args); 

回答

0

使用類似下面,

$args = array(
    'meta_query' => array(
     'relation' => 'OR', 
      array(
       'key'  => 'country', 
       'value' => 'Israel', 
       'compare' => '=' 
      ), 
      array(
       'key'  => 'age', 
       'value' => array(20, 30), 
       'type' => 'numeric', 
       'compare' => 'BETWEEN' 
      ) 
    ) 
); 
$user_query = new WP_User_Query($args); 

更多價:https://codex.wordpress.org/Class_Reference/WP_User_Query

+0

我想獲取動態值,而不是陣列中的靜態定義。我對你提供的解決方案有點懷疑。 –

+0

您可以在循環中使用meta_key和value。我只是添加例如,你可以修改就像你想要的。 – GNANA