Ticket #15292: 16573.diff
File 16573.diff, 1.9 KB (added by , 14 years ago) |
---|
-
wp-includes/meta.php
387 387 $i = 0; 388 388 foreach ( $meta_query as $q ) { 389 389 $meta_key = isset( $q['key'] ) ? trim( $q['key'] ) : ''; 390 $meta_value = isset( $q['value'] ) ? $q['value'] : '';391 390 $meta_compare = isset( $q['compare'] ) ? strtoupper( $q['compare'] ) : '='; 392 391 $meta_type = isset( $q['type'] ) ? strtoupper( $q['type'] ) : 'CHAR'; 393 392 … … 413 412 if ( !empty( $meta_key ) ) 414 413 $where .= $wpdb->prepare( " AND $alias.meta_key = %s", $meta_key ); 415 414 415 if ( !isset( $q['value'] ) ) 416 continue; 417 $meta_value = $q['value']; 418 416 419 if ( in_array( $meta_compare, array( 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN' ) ) ) { 417 420 if ( ! is_array( $meta_value ) ) 418 $meta_value = preg_split( '/[,\s]+/', $meta_value ); 421 $meta_value = array_filter( preg_split( '/[,\s]+/', $meta_value ) ); 422 423 if ( empty( $meta_value ) ) 424 continue; 419 425 } else { 420 426 $meta_value = trim( $meta_value ); 421 427 } 422 428 423 if ( empty( $meta_value ) )424 continue;425 426 429 if ( 'IN' == substr( $meta_compare, -2) ) { 427 430 $meta_compare_string = '(' . substr( str_repeat( ',%s', count( $meta_value ) ), 1 ) . ')'; 428 431 } elseif ( 'BETWEEN' == substr( $meta_compare, -7) ) { … … 457 460 $meta_query = array(); 458 461 459 462 // Simple query needs to be first for orderby=meta_value to work correctly 460 foreach ( array( 'key', ' value', 'compare', 'type' ) as $key ) {463 foreach ( array( 'key', 'compare', 'type' ) as $key ) { 461 464 if ( !empty( $qv[ "meta_$key" ] ) ) 462 465 $meta_query[0][ $key ] = $qv[ "meta_$key" ]; 463 466 } 464 467 468 // WP_Query sets 'meta_value' = '' by default 469 if ( isset( $qv[ 'meta_value' ] ) && '' !== $qv[ 'meta_value' ] ) 470 $meta_query[0]['value'] = $qv[ 'meta_value' ]; 471 465 472 if ( !empty( $qv['meta_query'] ) && is_array( $qv['meta_query'] ) ) { 466 473 $meta_query = array_merge( $meta_query, $qv['meta_query'] ); 467 474 }