web-dev-qa-db-fra.com

interroger plusieurs taxonomies

J'ai une fonction configurée pour afficher les "produits similaires", c'est-à-dire les produits qui partagent le même terme de taxonomie products-category. Cela fonctionne très bien, mais je souhaite affiner encore davantage la fonction et la rendre plus spécifique. Donc, je veux qu'il regarde 2 taxonomies (product-category et space) pour trouver des produits similaires. Le balisage actuel comme suit:

    <?php  
    $terms = wp_get_post_terms( $post->ID, 'products-category' );
    if($terms){
      // post has course_type terms attached
      $course_terms = array();
      foreach ($terms as $term){
       $course_terms[] = $term->slug;
      }

     $original_query = $wp_query;
     $wp_query = null;
     $wp_query = new WP_Query(
        array(
            'posts_per_page' => '4',
            'post_type' => 'regularproducts',
            'tax_query' => array(
                array(
                    'taxonomy' => 'products-category',
                    'field' => 'slug',
                    'terms' => $course_terms, //the taxonomy terms I'd like to dynamically query
                ),
            ),
            'orderby' => 'title',
            'order' => 'ASC',
        )
    );

    if ( have_posts() ): ?>

    <?php while (have_posts() ) : the_post(); ?> //etc...

Donc, actuellement, il ne regarde que la taxonomie products-category pour des produits similaires (posts), mais je veux qu'il examine BOTH product-category et space pour afficher des produits similaires plus spécifiques, si possible. Toutes les suggestions seraient grandement appréciées!

1
user1374796

Tout d’abord, obtenez tous les termes de la taxonomie personnalisée space par identifiant de poste actuel.

$space_terms = wp_get_post_terms( $post->ID, 'space' );
if( $space_terms ) {
  $space_terms = array();
  foreach( $space_terms as $term ) {
   $space_terms[] = $term->slug;
  }
}

Vous devez spécifier la relation logique entre chaque tableau de taxonomie interne lorsqu'il en existe plusieurs.

La clé relation dans le tableau décrit la relation. Les valeurs possibles sont OR et AND.

'tax_query' => array(
    'relation' => 'OR',
    array(
        'taxonomy' => 'products-category',
        'field'    => 'slug',
        'terms'    => $course_terms,
    ),
    array(
        'taxonomy' => 'space',
        'field'    => 'slug',
        'terms'    => $space_terms,
    ),
),
5
SLH

Il suffit d’obtenir d’abord tous les termes: Ici, j’ai utilisé un type de propriété personnalisé, par exemple

$property_statu_terms = wp_get_post_terms( $post->ID, 'property_status', array(  'fields' => 'ids' ));
$property_type_terms = wp_get_post_terms( $post->ID, 'property_type', array(  'fields' => 'ids' ));
$property_city_terms = wp_get_post_terms( $post->ID, 'property_city', array(  'fields' => 'ids' ));
$property_state_terms = wp_get_post_terms( $post->ID, 'property_state', array(  'fields' => 'ids' ));
$property_feature_terms = wp_get_post_terms( $post->ID, 'property_feature', array(  'fields' => 'ids' ));

Utilisez relation[OR] ou [AND] pour obtenir les publications de votre choix.

$query = new WP_Query( array(

    'post_type'             => 'property',
    'posts_per_page'        => 3,
    'orderby'               => 'Rand',
    'post__not_in'          => array( $post->ID ),
    'ignore_sticky_posts'   => 1,
    'tax_query' => array(
        'relation' => 'OR',
        array(
            'taxonomy' => 'property_status',
            'field'    => 'id',
            'terms'    => $property_statu_terms,
        ),
        array(
            'taxonomy' => 'property_type',
            'field'    => 'id',
            'terms'    => $property_type_terms,
        ),
        array(
            'taxonomy' => 'property_city',
            'field'    => 'id',
            'terms'    => $property_city_terms,
        ),
        array(
            'taxonomy' => 'property_state',
            'field'    => 'id',
            'terms'    => $property_state_terms,
        ),
        array(
            'taxonomy' => 'property_feature',
            'field'    => 'id',
            'terms'    => $property_feature_terms,
        ),
    ),

));
1
Razon K.