mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-04-05 13:14:29 +00:00
Remove extraneous table join in get_adjacent_post().
Since [29248], a table join has not been necessary to process the `$excluded_terms` parameter of `get_adjacent_post()`. Aside from adding extra overhead, this join meant that post records that don't have any corresponding rows in `wp_term_relationships` were erroneously excluded from results. Fixes #32833. git-svn-id: https://develop.svn.wordpress.org/trunk@34088 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -1492,9 +1492,6 @@ function get_adjacent_post( $in_same_term = false, $excluded_terms = '', $previo
|
||||
$where = '';
|
||||
|
||||
if ( $in_same_term || ! empty( $excluded_terms ) ) {
|
||||
$join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";
|
||||
$where = $wpdb->prepare( "AND tt.taxonomy = %s", $taxonomy );
|
||||
|
||||
if ( ! empty( $excluded_terms ) && ! is_array( $excluded_terms ) ) {
|
||||
// back-compat, $excluded_terms used to be $excluded_terms with IDs separated by " and "
|
||||
if ( false !== strpos( $excluded_terms, ' and ' ) ) {
|
||||
@@ -1508,6 +1505,9 @@ function get_adjacent_post( $in_same_term = false, $excluded_terms = '', $previo
|
||||
}
|
||||
|
||||
if ( $in_same_term ) {
|
||||
$join .= " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";
|
||||
$where .= $wpdb->prepare( "AND tt.taxonomy = %s", $taxonomy );
|
||||
|
||||
if ( ! is_object_in_taxonomy( $post->post_type, $taxonomy ) )
|
||||
return '';
|
||||
$term_array = wp_get_object_terms( $post->ID, $taxonomy, array( 'fields' => 'ids' ) );
|
||||
|
||||
Reference in New Issue
Block a user