我正在开发一个wordpress仪表板插件,用于在wordpress表中的管理仪表板中显示订阅者列表。
除了我需要订阅者时所有注册用户都显示在数组中的事实之外,一切都正常工作。我正在使用以下代码创建数组..
function prepare_items() {
$per_page = 5;
$columns = $this->get_columns(); $hidden = array(); $sortable = $this->get_sortable_columns();
$this->_column_headers = array($columns, $hidden, $sortable);
global $wpdb;
$data = $wpdb->get_results("SELECT * FROM $wpdb->users", ARRAY_A);
$i = 0;
foreach($data as $single) {
$meta = $wpdb->get_results(
"SELECT meta_value
FROM $wpdb->usermeta
WHERE user_id = $single[ID]
AND (meta_key = 'first_name' OR meta_key = 'last_name' OR meta_key = 'wp_user_level')
ORDER BY meta_key",
ARRAY_A
);
$data[$i]['first_name'] = $meta[0]['meta_value'];
$data[$i]['last_name'] = $meta[1]['meta_value'];
$data[$i]['wp_user_level'] = $meta[2]['meta_value'];
$i++;
}
echo '<pre>';
print_r($data2);
echo '</pre>';
通过使用print_r,我可以看到两个表wp_users和wp_usermeta正确连接,我需要的所有细节都返回到数组中。
我现在需要做的是使用某种array_filter只返回wp_user_level为0(订阅者)的条目。
我试过以下......
$data = array_filter($data, 'filter_subscribers');
function filter_subscribers()
{
return $data2['wp_user_level'] == '0';
}
但它对我不起作用,有人可以提出任何建议吗?
答案 0 :(得分:1)
用户的角色作为序列化数组数据存储在meta_value中,使事情变得过于复杂。
为什么不使用WordPress构建的WP_User_Query类为您完成工作? http://codex.wordpress.org/Class_Reference/WP_User_Query
$wp_user_search = new WP_User_Query( array( 'role' => 'subscriber' ) );
$subscribers = $wp_user_search->get_results();