Wordpress中的Meta Query被忽略了

时间:2016-01-18 10:55:28

标签: php wordpress

我写了一个名为'员工'的自定义帖子类型。现在尝试通过在显示部门页面后调用此帖子类型来查询它。我创建了一个带有几个参数的自定义元框,例如部门,有一个下拉列表,因此人们可以轻松地将人员分配到正确的部门。如果符合标准,则应显示员工的图片(或者在我的情况下,单词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(我到目前为止输入的员工总数)显示。看起来它忽略了元查询。

任何人都可以帮我这个吗?

1 个答案:

答案 0 :(得分:0)

我在数据库中查看输入方式。我意识到我前一段时间用正确的刻字更新了文件。 Wordpress没有更新数据库中的这些更改,因此我不得不调用旧的键名,而不是新的键名。我想这是我身上的一个缺陷,为什么它无法读取它。现在正确的查询如下。

$args = array(
    'post_type' => 'employees',
    'meta_query' => array(
        array(
            'key'     => 'shm_text',
            'value' => $page,
            'compare' => '='
        )
    )
);