【问题标题】:sort user in admin by meta value for users.php按 users.php 的元值对管理员中的用户进行排序
【发布时间】:2014-03-18 19:39:11
【问题描述】:

我正在尝试在管理仪表板中对用户进行自定义搜索并使用它: 我在functions.php文件中添加了这个:

add_filter( 'pre_user_query','ba_admin_posts_filter' );
add_action( 'restrict_manage_users', 'ba_admin_posts_filter_restrict_manage_posts' );
function ba_admin_posts_filter( $query )
{
    global $pagenow;
    if ( is_admin() && $pagenow=='users.php' && isset($_GET['ADMIN_FILTER_FIELD_NAME']) && $_GET['ADMIN_FILTER_FIELD_NAME'] != '') {
        $query->query_vars['meta_key'] = $_GET['ADMIN_FILTER_FIELD_NAME'];
    if (isset($_GET['ADMIN_FILTER_FIELD_VALUE']) && $_GET['ADMIN_FILTER_FIELD_VALUE'] != '')
        $query->query_vars['meta_value'] = $_GET['ADMIN_FILTER_FIELD_VALUE'];
    }
}
function ba_admin_posts_filter_restrict_manage_posts()
{
    global $wpdb;
    $sql = 'SELECT DISTINCT meta_key FROM '.$wpdb->usermeta.' ORDER BY 1';
    $fields = $wpdb->get_results($sql, ARRAY_N);
    print_r($fields);
?>
<select name="ADMIN_FILTER_FIELD_NAME">
<option value=""><?php _e('Filter By Custom Fields', 'baapf'); ?></option>
<?php
    $current = isset($_GET['ADMIN_FILTER_FIELD_NAME'])? $_GET['ADMIN_FILTER_FIELD_NAME']:'';
    $current_v = isset($_GET['ADMIN_FILTER_FIELD_VALUE'])? $_GET['ADMIN_FILTER_FIELD_VALUE']:'';
    foreach ($fields as $field) {
        if (substr($field[0],0,1) != "_"){
        printf
            (
                '<option value="%s"%s>%s</option>',
                $field[0],
                $field[0] == $current? ' selected="selected"':'',
                $field[0]
            );
        }
    }
?>
</select> <?php _e('Value:', 'baapf'); ?><input type="TEXT" name="ADMIN_FILTER_FIELD_VALUE" value="<?php echo $current_v; ?>" />
<?php
}

通过这个,我在选择框中获得了自定义字段和一个用于手动输入的文本框,但它没有根据自定义字段值对用户表进行排序。 例如,如果任何用户具有“学生”之类的元值,则列表应按学生排序。 我应该怎么做才能让它变得好.....帮助将不胜感激..

【问题讨论】:

标签: php wordpress


【解决方案1】:

这很正常,您的 SQL 中的ORDER BY 1 阻止了它。

您应该将此子句替换为实际排序,ORDER BY 1 表示查询结果将按表的第一列排序(默认升序),本例为meta_key

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-03-28
    • 1970-01-01
    • 1970-01-01
    • 2019-08-12
    • 1970-01-01
    相关资源
    最近更新 更多