mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-03 15:08:10 +01:00
Site search performance tweaks. Use subquery for registration log queries to allow cross DB queries. Lose order by id by default. Search only by blog_id for numeric search strings. see #15170
git-svn-id: http://svn.automattic.com/wordpress/trunk@16489 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
42ce1825ac
commit
c1812e444d
@ -54,28 +54,29 @@ class WP_MS_Sites_List_Table extends WP_List_Table {
|
|||||||
// Nothing to do.
|
// Nothing to do.
|
||||||
} elseif ( preg_match('/^[0-9]+\./', $s) ) {
|
} elseif ( preg_match('/^[0-9]+\./', $s) ) {
|
||||||
// IP address
|
// IP address
|
||||||
|
$reg_blog_ids = $wpdb->get_col( "SELECT blog_id FROM {$wpdb->registration_log} WHERE {$wpdb->registration_log}.IP LIKE ( '{$like_s}$wild' )" );
|
||||||
|
|
||||||
|
if ( !$reg_blog_ids )
|
||||||
|
$reg_blog_ids = array( 0 );
|
||||||
|
|
||||||
$query = "SELECT *
|
$query = "SELECT *
|
||||||
FROM {$wpdb->blogs}, {$wpdb->registration_log}
|
FROM {$wpdb->blogs}
|
||||||
WHERE site_id = '{$wpdb->siteid}'
|
WHERE site_id = '{$wpdb->siteid}'
|
||||||
AND {$wpdb->blogs}.blog_id = {$wpdb->registration_log}.blog_id
|
AND {$wpdb->blogs}.blog_id IN (" . implode( ', ', $reg_blog_ids ) . ")";
|
||||||
AND {$wpdb->registration_log}.IP LIKE ( '{$like_s}$wild' )";
|
|
||||||
} else {
|
} else {
|
||||||
if ( is_subdomain_install() ) {
|
if ( is_numeric($s) ) {
|
||||||
|
$query .= " AND ( {$wpdb->blogs}.blog_id = '{$like_s}' )";
|
||||||
|
} elseif ( is_subdomain_install() ) {
|
||||||
$blog_s = str_replace( '.' . $current_site->domain, '', $like_s );
|
$blog_s = str_replace( '.' . $current_site->domain, '', $like_s );
|
||||||
$blog_s .= $wild . '.' . $current_site->domain;
|
$blog_s .= $wild . '.' . $current_site->domain;
|
||||||
$query .= " AND ( {$wpdb->blogs}.domain LIKE '$blog_s' ";
|
$query .= " AND ( {$wpdb->blogs}.domain LIKE '$blog_s' ) ";
|
||||||
} else {
|
} else {
|
||||||
if ( $like_s != trim('/', $current_site->path) )
|
if ( $like_s != trim('/', $current_site->path) )
|
||||||
$blog_s = $current_site->path .= $like_s . $wild . '/';
|
$blog_s = $current_site->path .= $like_s . $wild . '/';
|
||||||
else
|
else
|
||||||
$blog_s = $like_s;
|
$blog_s = $like_s;
|
||||||
$query .= " AND ( {$wpdb->blogs}.path LIKE '$blog_s' ";
|
$query .= " AND ( {$wpdb->blogs}.path LIKE '$blog_s' )";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( is_numeric($s) )
|
|
||||||
$query .= " OR {$wpdb->blogs}.blog_id = '{$like_s}' ";
|
|
||||||
|
|
||||||
$query .= ' )';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$order_by = isset( $_REQUEST['orderby'] ) ? $_REQUEST['orderby'] : 'id';
|
$order_by = isset( $_REQUEST['orderby'] ) ? $_REQUEST['orderby'] : 'id';
|
||||||
@ -86,12 +87,13 @@ class WP_MS_Sites_List_Table extends WP_List_Table {
|
|||||||
} elseif ( $order_by == 'blogname' ) {
|
} elseif ( $order_by == 'blogname' ) {
|
||||||
$query .= ' ORDER BY domain ';
|
$query .= ' ORDER BY domain ';
|
||||||
} else {
|
} else {
|
||||||
$order_by = 'id';
|
$order_by = null;
|
||||||
$query .= " ORDER BY {$wpdb->blogs}.blog_id ";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$order = ( isset( $_REQUEST['order'] ) && 'DESC' == strtoupper( $_REQUEST['order'] ) ) ? "DESC" : "ASC";
|
if ( isset( $order_by ) ) {
|
||||||
$query .= $order;
|
$order = ( isset( $_REQUEST['order'] ) && 'DESC' == strtoupper( $_REQUEST['order'] ) ) ? "DESC" : "ASC";
|
||||||
|
$query .= $order;
|
||||||
|
}
|
||||||
|
|
||||||
// Don't do an unbounded count on large networks
|
// Don't do an unbounded count on large networks
|
||||||
if ( ! $large_network )
|
if ( ! $large_network )
|
||||||
|
Loading…
Reference in New Issue
Block a user