WordPress.org

Make WordPress Core

Ticket #12891: relation-or.4.diff

File relation-or.4.diff, 1.8 KB (added by scribu, 8 years ago)
  • wp-includes/taxonomy.php

     
    524524        global $wpdb;
    525525
    526526        $join = '';
    527         $where = '';
     527        $where = array();
    528528        $i = 0;
     529
     530        if ( isset( $tax_query['relation'] ) && strtoupper( $tax_query['relation'] ) == 'OR' ) {
     531                $relation = 'OR';
     532        } else {
     533                $relation = 'AND';
     534        }
     535
    529536        foreach ( $tax_query as $query ) {
     537                if ( ! is_array( $query ) )
     538                        continue;
     539
    530540                extract( wp_parse_args( $query, array(
    531541                        'taxonomy' => array(),
    532542                        'terms' => array(),
     
    566576                }
    567577
    568578                if ( 'IN' == $operator ) {
    569                         if ( empty( $terms ) )
    570                                 return array( 'join' => '', 'where' => ' AND 0 = 1');
    571579
     580                        if ( empty( $terms ) ) {
     581                                if ( 'OR' == $relation )
     582                                        continue;
     583                                else
     584                                        return array( 'join' => '', 'where' => ' AND 0 = 1' );
     585                        }
     586
    572587                        $terms = implode( ',', $terms );
    573588
    574589                        $alias = $i ? 'tt' . $i : $wpdb->term_relationships;
     
    577592                        $join .= $i ? " AS $alias" : '';
    578593                        $join .= " ON ($primary_table.$primary_id_column = $alias.object_id)";
    579594
    580                         $where .= " AND $alias.term_taxonomy_id $operator ($terms)";
    581 
    582                         $i++;
     595                        $where[] = "$alias.term_taxonomy_id $operator ($terms)";
    583596                }
    584597                elseif ( 'NOT IN' == $operator ) {
     598
    585599                        if ( empty( $terms ) )
    586600                                continue;
    587601
    588602                        $terms = implode( ',', $terms );
    589603
    590                         $where .= " AND $primary_table.$primary_id_column NOT IN (
    591                                 SELECT object_id 
    592                                 FROM $wpdb->term_relationships 
     604                        $where[] = "$primary_table.$primary_id_column NOT IN (
     605                                SELECT object_id
     606                                FROM $wpdb->term_relationships
    593607                                WHERE term_taxonomy_id IN ($terms)
    594608                        )";
    595609                }
     610
     611                $i++;
    596612        }
    597613
     614        if ( !empty( $where ) )
     615                $where = ' AND ( ' . implode( " $relation ", $where ) . ' )';
     616        else
     617                $where = '';
     618
    598619        return compact( 'join', 'where' );
    599620}
    600621