WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru Получай пассивный доход от сайта
функция не описана

Automattic\WooCommerce\Internal\ProductAttributesLookup

Filterer::get_product_counts_query_not_using_lookup_table() private WC 1.0

Get the query for counting products by terms NOT using the product attributes lookup table.

{} Это метод класса: Filterer{}

Хуков нет.

Возвращает

Массив. An array of SQL query parts.

Использование

// private - только в коде основоного (родительского) класса
$result = $this->get_product_counts_query_not_using_lookup_table( $tax_query, $meta_query, $term_ids );
$tax_query(\WP_Tax_Query) (обязательный)
The current main tax query.
$meta_query(\WP_Meta_Query) (обязательный)
The current main meta query.
$term_ids(строка) (обязательный)
The term ids to include in the search.

Код Filterer::get_product_counts_query_not_using_lookup_table() WC 5.5.2

<?php
private function get_product_counts_query_not_using_lookup_table( $tax_query, $meta_query, $term_ids ) {
	global $wpdb;

	$meta_query_sql = $meta_query->get_sql( 'post', $wpdb->posts, 'ID' );
	$tax_query_sql  = $tax_query->get_sql( $wpdb->posts, 'ID' );

	// Generate query.
	$query           = array();
	$query['select'] = "SELECT COUNT( DISTINCT {$wpdb->posts}.ID ) AS term_count, terms.term_id AS term_count_id";
	$query['from']   = "FROM {$wpdb->posts}";
	$query['join']   = "
		INNER JOIN {$wpdb->term_relationships} AS term_relationships ON {$wpdb->posts}.ID = term_relationships.object_id
		INNER JOIN {$wpdb->term_taxonomy} AS term_taxonomy USING( term_taxonomy_id )
		INNER JOIN {$wpdb->terms} AS terms USING( term_id )
		" . $tax_query_sql['join'] . $meta_query_sql['join'];

	$term_ids_sql   = $this->get_term_ids_sql( $term_ids );
	$query['where'] = "
		WHERE {$wpdb->posts}.post_type IN ( 'product' )
		AND {$wpdb->posts}.post_status = 'publish'
		{$tax_query_sql['where']} {$meta_query_sql['where']}
		AND terms.term_id IN $term_ids_sql";

	$search_query_sql = \WC_Query::get_main_search_query_sql();
	if ( $search_query_sql ) {
		$query['where'] .= ' AND ' . $search_query_sql;
	}

	$query['group_by'] = 'GROUP BY terms.term_id';

	return $query;
}