Перейти к содержанию
m4reve

Список производителей. Вывод списка категорий в которых есть товары выбранного производителя.

Рекомендуемые сообщения

Подскажите, как сделать вывод списка категорий в которых присутствуют товары "выбранного производителя" на странице списка производителей.  Находил решение, которое выводило список категорий на странице с описанием производителя, но как переделять его для страницы списка производителей так и не понял.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Ну, перекрестные запросы и все такое. Это достаточно ресурсоемкие запросы должны получиться, так что без кэширования не обойтись.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Ну, перекрестные запросы и все такое. Это достаточно ресурсоемкие запросы должны получиться, так что без кэширования не обойтись.

По подробнее можете рассказать? 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Код не проверял, но должен работать. Готовая функция для получения списка категорий у производителя с кэшированием:

public function getManufacturerCategories($manufacturer_id)
{
    
    $cache_name = 'manufacturer.categories';
    
    $cached = $this->cache->get($cache_name);

    if ($cached && isset($cached[$manufacturer_id])) {
    
        return $cached[$manufacturer_id];
    
    } else {
        
        $query = $this->db->query("
        SELECT 
            DISTINCT c.category_id, cd.name
        FROM
        " . DB_PREFIX . "manufacturer m 
            LEFT JOIN " . DB_PREFIX . "product p ON (m.manufacturer_id = p.manufacturer_id)
            LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p2c.product_id = p.product_id)
            LEFT JOIN " . DB_PREFIX . "category c ON (c.category_id = p2c.category_id)
            LEFT JOIN " . DB_PREFIX . "category_description cd ON (cd.category_id = p2c.category_id)
        WHERE
            p.status = 1
            AND m.manufacturer_id = '" . (int) $manufacturer_id . "'
            AND c.status= 1
        ");
        
        $cached[$manufacturer_id] = $query->rows;
        
        $this->cache->set($cache_name, $cached);
        
        return $query->rows;
    }
}
 

Без

public function getManufacturerCategories($manufacturer_id)
{

    $query = $this->db->query("
    SELECT 
        DISTINCT c.category_id,cd.name
    FROM
    " . DB_PREFIX . "manufacturer m 
        LEFT JOIN " . DB_PREFIX . "product p ON (m.manufacturer_id = p.manufacturer_id)
        LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p2c.product_id = p.product_id)
        LEFT JOIN " . DB_PREFIX . "category c ON (c.category_id = p2c.category_id)
        LEFT JOIN " . DB_PREFIX . "category_description cd ON (cd.category_id = p2c.category_id)
    WHERE
        p.status = 1
        AND m.manufacturer_id = '" . (int) $manufacturer_id . "'
        AND c.status= 1
    ");
    
    return $query->rows;
}

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.