我写了一个名为'员工'的自定义帖子类型。现在尝试通过在显示部门页面后调用此帖子类型来查询它。我创建了一个带有几个参数的自定义元框,例如部门,有一个下拉列表,因此人们可以轻松地将人员分配到正确的部门。如果符合标准,则应显示员工的图片(或者在我的情况下,单词crap
作为测试)。
但是,我似乎遇到了尝试获取正确查询的问题。我的代码如下。我需要清除一些东西,它的代码正在进行中,所以不要贬低它的编程方式。它只是现在的查询。
这是元框的代码
$prefix = 'shm_';
$meta_box = array(
'id' => 'meta-employees',
'title' => 'Overige informatie',
'page' => 'employees',
'context' => 'normal',
'priority' => 'high',
'fields' => array(
array(
'name' => 'position',
'desc' => 'The name of the job position',
'id' => $prefix . 'position',
'type' => 'text',
'std' => ''
),
array(
'name' => 'department',
'desc' => 'Select the department this employee is working in',
'id' => $prefix . 'department',
'type' => 'select',
'options' => array('Board', 'Sales, Marketing & Revenue', 'Option 3', 'Option 4', 'Option 5', 'Option 6')
)
)
);
这是针对查询的
<?php
if(!is_front_page()){
if (is_page('board')){
$page = 'board';
}elseif (is_page('sales-marketing-revenue')){
$page = 'Sales, Marketing & Revenue';
}
echo $page;
$i = 0;
$args = array(
'numberposts' => -1,
'post_type' => 'employees',
'meta_query' => array(
'key' => 'department',
'value' => $page,
'compare' => '=',
)
);
query_posts($args);
if ( have_posts() ) :
while ( have_posts() ) : the_post();
echo "crap";
?>
<?php endwhile; ?>
<?php endif; ?>
<?php } ?>
这篇文章在技术上有效,但它会吐出所有员工而不是我在特定部门设置的员工,例如board
。当我打印数组时,一切似乎都能正常工作。
Array ( [numberposts] => -1 [post_type] => employees [meta_query] => Array ( [key] => department [value] => Sales, Marketing & Revenue [compare] => = ) )
然而销售营销&amp;收入只有1个人附加,而不是3(我到目前为止输入的员工总数)显示。看起来它忽略了元查询。
任何人都可以帮我这个吗?
答案 0 :(得分:0)
我在数据库中查看输入方式。我意识到我前一段时间用正确的刻字更新了文件。 Wordpress没有更新数据库中的这些更改,因此我不得不调用旧的键名,而不是新的键名。我想这是我身上的一个缺陷,为什么它无法读取它。现在正确的查询如下。
$args = array(
'post_type' => 'employees',
'meta_query' => array(
array(
'key' => 'shm_text',
'value' => $page,
'compare' => '='
)
)
);