Prevent ambiguous table aliases in wp_post_mime_type_where. props stephdau, jfarthing84, fixes #12750.

git-svn-id: https://develop.svn.wordpress.org/trunk@14478 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2010-05-06 18:03:05 +00:00
parent 0b3e082d6e
commit cba25aba7e
2 changed files with 11 additions and 7 deletions

View File

@ -1573,9 +1573,10 @@ function wp_match_mime_types($wildcard_mime_types, $real_mime_types) {
* @since 2.5.0 * @since 2.5.0
* *
* @param string|array $mime_types List of mime types or comma separated string of mime types. * @param string|array $mime_types List of mime types or comma separated string of mime types.
* @param string $table_alias Optional. Specify a table alias, if needed. 
* @return string The SQL AND clause for mime searching. * @return string The SQL AND clause for mime searching.
*/ */
function wp_post_mime_type_where($post_mime_types) { function wp_post_mime_type_where($post_mime_types, $table_alias = '') {
$where = ''; $where = '';
$wildcards = array('', '%', '%/%'); $wildcards = array('', '%', '%/%');
if ( is_string($post_mime_types) ) if ( is_string($post_mime_types) )
@ -1603,9 +1604,9 @@ function wp_post_mime_type_where($post_mime_types) {
return ''; return '';
if ( false !== strpos($mime_pattern, '%') ) if ( false !== strpos($mime_pattern, '%') )
$wheres[] = "post_mime_type LIKE '$mime_pattern'"; $wheres[] = empty($table_alias) ? "post_mime_type LIKE '$mime_pattern'" : "$table_alias.post_mime_type LIKE '$mime_pattern'";
else else
$wheres[] = "post_mime_type = '$mime_pattern'"; $wheres[] = empty($table_alias) ? "post_mime_type = '$mime_pattern'" : "$table_alias.post_mime_type = '$mime_pattern'";
} }
if ( !empty($wheres) ) if ( !empty($wheres) )
$where = ' AND (' . join(' OR ', $wheres) . ') '; $where = ' AND (' . join(' OR ', $wheres) . ') ';

View File

@ -2026,13 +2026,14 @@ class WP_Query {
$post_ids = get_objects_in_term($term_ids, $taxonomy); $post_ids = get_objects_in_term($term_ids, $taxonomy);
if ( !is_wp_error($post_ids) && !empty($post_ids) ) { if ( !is_wp_error($post_ids) && !empty($post_ids) ) {
$whichcat .= " AND $wpdb->posts.ID IN (" . implode(', ', $post_ids) . ") "; $whichcat .= " AND $wpdb->posts.ID IN (" . implode(', ', $post_ids) . ") ";
if ( '' === $post_type ) { if ( empty($post_type) ) {
$post_type = 'any'; $post_type = 'any';
$post_status_join = true; $post_status_join = true;
} elseif ( in_array('attachment', (array)$post_type) ) { } elseif ( in_array('attachment', (array)$post_type) ) {
$post_status_join = true; $post_status_join = true;
} }
$q['post_status'] = 'publish'; if ( empty($q['post_status']) )
$q['post_status'] = 'publish';
} else { } else {
$whichcat = " AND 0 "; $whichcat = " AND 0 ";
} }
@ -2083,8 +2084,10 @@ class WP_Query {
// MIME-Type stuff for attachment browsing // MIME-Type stuff for attachment browsing
if ( isset($q['post_mime_type']) && '' != $q['post_mime_type'] ) if ( isset($q['post_mime_type']) && '' != $q['post_mime_type'] ) {
$whichmimetype = wp_post_mime_type_where($q['post_mime_type']); $table_alias = $post_status_join ? $wpdb->posts : '';
$whichmimetype = wp_post_mime_type_where($q['post_mime_type'], $table_alias);
}
$where .= $search . $whichcat . $whichauthor . $whichmimetype; $where .= $search . $whichcat . $whichauthor . $whichmimetype;