BP_User_Query::do_user_ids_query()

Query for IDs of users that match the query parameters.

Description

Perform a database query to specifically get only user IDs, using existing query variables set previously in the constructor.

Also used to quickly perform user total counts.

Source

File: bp-core/classes/class-bp-user-query.php

514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
public function do_user_ids_query() {
    global $wpdb;
 
    // If counting using SQL_CALC_FOUND_ROWS, set it up here.
    if ( 'sql_calc_found_rows' == $this->query_vars['count_total'] ) {
        $this->uid_clauses['select'] = str_replace( 'SELECT', 'SELECT SQL_CALC_FOUND_ROWS', $this->uid_clauses['select'] );
    }
 
    if ( is_array( $this->uid_clauses['orderby'] ) ) {
        $orderby_multiple = array();
        foreach ( $this->uid_clauses['orderby'] as $part ) {
            $orderby_multiple[] = $part[0] . ' ' . $part[1];//column_name DESC/ASC
        }
 
        $this->uid_clauses['orderby'] = "ORDER BY " . implode( ', ', $orderby_multiple );
        $this->uid_clauses['order'] = "";
    }
 
    // Get the specific user ids.
    $this->user_ids = $wpdb->get_col( "{$this->uid_clauses['select']} {$this->uid_clauses['where']} {$this->uid_clauses['orderby']} {$this->uid_clauses['order']} {$this->uid_clauses['limit']}" );
 
    // Get the total user count.
    if ( 'sql_calc_found_rows' == $this->query_vars['count_total'] ) {
 
        /**
         * Filters the found user SQL statements before query.
         *
         * If "sql_calc_found_rows" is the provided count_total query var
         * then the value will be "SELECT FOUND_ROWS()". Otherwise it will
         * use a "SELECT COUNT()" query statement.
         *
         * @since BuddyPress 1.7.0
         *
         * @param string        $value SQL statement to select FOUND_ROWS().
         * @param BP_User_Query $this  Current BP_User_Query instance.
         */
        $this->total_users = $wpdb->get_var( apply_filters( 'bp_found_user_query', "SELECT FOUND_ROWS()", $this ) );
    } elseif ( 'count_query' == $this->query_vars['count_total'] ) {
        $count_select      = preg_replace( '/^SELECT.*?FROM (\S+) u/', "SELECT COUNT(u.{$this->uid_name}) FROM $1 u", $this->uid_clauses['select'] );
 
        /** This filter is documented in bp-core/classes/class-bp-user-query.php */
        $this->total_users = $wpdb->get_var( apply_filters( 'bp_found_user_query', "{$count_select} {$this->uid_clauses['where']}", $this ) );
    }
}

Changelog

Changelog
Version Description
BuddyPress 1.7.0 Introduced.

Questions?

We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.