0

我正在使用一个自定义字段来存储用户输入的日期的时间戳。我想显示按该自定义日期排序的帖子,但他们拒绝按自定义字段排序。

在这里,我使用此自定义元框工具注册自定义字段 - https://github.com/jaredatch/Custom-Metaboxes-and-Fields-for-WordPress

// the prefix is _cmb_
array(
    'name' => 'Start Time',
    'id'   => $prefix . 'start_time',
    'type' => 'text_datetime_timestamp',
),

然后我使用 WP_Query 使用以下参数遍历帖子:

$args = array(
  'post_type' => 'talks',
  'posts_per_page' => -1,
  'orderby' => '_cmb_start_time',
  'order' => 'ASC'
); // show talks ordered by start time

$custom_query = new WP_Query($args);

这会按照添加的顺序打印帖子,而不是按照自定义字段日期的顺序。


更新

我还试图通过另一个自定义字段类型“房间”进行过滤,其值等于“房间 1”:

$args = array(
  'post_type' => 'talks',
  'posts_per_page' => -1,
  'orderby' => '_cmb_start_time',
  'order' => 'ASC',
  'meta_key' => 'room',
  'meta_value' => 'room 1'
);

解决方案:

使用@joebuckle 的解决方案,我最终得到了这个效果很好的版本:

$args = array(
  'post_type' => 'talks',
  'posts_per_page' => -1,
  'meta_key' => '_cmb_start_time',
  'orderby' => 'meta_value_num',
  'order' => 'ASC',
  'meta_query' => array(
    array(
      'key' => 'room',
      'value' => 'room 1',
      'compare' => '='
    )
  ));
4

1 回答 1

0

改为这样尝试(参考WP_Query

$args = array(
    'post_type' => 'talks',
    'posts_per_page' => -1,
    'meta_key' => '_cmb_start_time',
    'orderby' => 'meta_value_num',
    'order' => 'ASC'
); // show talks ordered by start time

$custom_query = new WP_Query($args);
于 2013-09-27T15:40:20.157 回答