繁体   English   中英

WordPress SQL 按用户角色获取特定用户

[英]WordPress SQL get specific user by user role

嗨,我正在尝试通过 SQL 查询从数据库中获取特定用户。 还试图添加一些条件。 User role name is: Student但我的代码无法获得正确的结果。

SELECT um.user_id, um.meta_key, um.meta_value, u.user_email 
FROM wp_usermeta AS um INNER JOIN wp_users AS u ON (u.ID = um.user_id) 
WHERE meta_key IN ('first_name', 'last_name','role') AND (meta_value NOT LIKE '%Student' AND u.user_email NOT LIKE '%@yourdomain.com')

您可以使用此函数按角色获取一组用户。

# This goes in functions.php
function get_users_by_role($role, $orderby, $order) {
    $args = array(
        'role'    => $role,
        'orderby' => $orderby,
        'order'   => $order
    );

    $users = get_users( $args );

    return $users;
}

然后你可以像这样使用它:

$users = get_users_by_role('student', 'user_nicename', 'ASC');

或者你可以像这样使用get_users()

$students = get_users( array( 'role__in' => array( 'student' ) ) );

或者

$students = get_users( 'role=student' );

或者 user_query 方式

$user_query = new WP_User_Query( array( 'role' => 'Student' ) ); 

如果你坚持使用 SQL,那么你可以使用

SELECT wp_users.ID, wp_users.user_nicename 
FROM wp_users INNER JOIN wp_usermeta 
ON wp_users.ID = wp_usermeta.user_id 
WHERE wp_usermeta.meta_key = 'wp_capabilities' 
AND wp_usermeta.meta_value LIKE '%student%' 
ORDER BY wp_users.user_nicename

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM