Speed (wp_)list_authors by consolidating some queries. Props graeme. fixes #1659

git-svn-id: http://svn.automattic.com/wordpress/trunk@5135 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
rob1n 2007-03-29 01:39:05 +00:00
parent e5b562a070
commit 4a6743b54c
1 changed files with 10 additions and 5 deletions

View File

@ -173,6 +173,8 @@ function get_author_name( $auth_id ) {
} }
function wp_list_authors($args = '') { function wp_list_authors($args = '') {
global $wpdb;
if ( is_array($args) ) if ( is_array($args) )
$r = &$args; $r = &$args;
else else
@ -183,14 +185,17 @@ function wp_list_authors($args = '') {
$r = array_merge($defaults, $r); $r = array_merge($defaults, $r);
extract($r); extract($r);
global $wpdb;
// TODO: Move select to get_authors(). // TODO: Move select to get_authors().
$query = "SELECT ID, user_nicename from $wpdb->users " . ($exclude_admin ? "WHERE user_login <> 'admin' " : '') . "ORDER BY display_name"; $authors = $wpdb->get_results("SELECT ID, user_nicename from $wpdb->users " . ($exclude_admin ? "WHERE user_login <> 'admin' " : '') . "ORDER BY display_name");
$authors = $wpdb->get_results($query);
$author_count = array();
foreach ((array) $wpdb->get_results("SELECT DISTINCT post_author, COUNT(ID) AS count FROM $wpdb->posts WHERE post_status = 'publish' GROUP BY post_author") as $row) {
$author_count[$row->post_author] = $row->count;
}
foreach ( (array) $authors as $author ) { foreach ( (array) $authors as $author ) {
$author = get_userdata( $author->ID ); $author = get_userdata( $author->ID );
$posts = get_usernumposts($author->ID); $posts = (isset($author_count[$author->ID])) ? $author_count[$author->ID] : 0;
$name = $author->nickname; $name = $author->nickname;
if ( $show_fullname && ($author->first_name != '' && $author->last_name != '') ) if ( $show_fullname && ($author->first_name != '' && $author->last_name != '') )