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

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

Всем здравствуйте. Суть задачи получить в массив $data['products'][] = array 

Количество оценок product.

То есть кол-во:

1 оценки,

2 оценки,

3 оценки и т.д до 5

Как понимаю нужно в модели создать

public function getTotalRatingsProductId($product_id) {

тут код запроса.

}

сделать запрос, не силен в этой части. Прошу помощи.

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


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

Может кому понадобится.

Критика приветствуется, так как додумал сам, хз может не очень верно вышло.

В model/catalog/product 

ocmod, ом добавил public function getMainProductStat($product_id), где и добавил запрос. Получив значение в массив.

SELECT product_id, rating, status, review_id FROM " . DB_PREFIX . "review WHERE product_id = '" . (int)$product_id . "' AND `rating` < '6' AND `status` = '1'

Ну и в controller/category Уже вывел.

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


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

Получить все оценки товара и рассортировать
 

public function getTotalRatingsProductId($product_id) {
    $ratings = array(1, 2, 3, 4, 5);
    
    $rating_data = array(
        1   => 0,
        2   => 0,
        3   => 0,
        4   => 0,
        5   => 0
    );
    
    $review_query = $this->db->query("SELECT review_id, rating FROM " . DB_PREFIX . "review WHERE status = '1' AND product_id = '" . (int)$product_id . "' ORDER BY review_id ASC");
    
    foreach ($review_query->rows as $row) {
        foreach ($ratings as $rating) {
            if ($row['rating'] == $rating) {
                $rating_data[$rating]++;
                
                break;
            }
        }
    }
    
    return $rating_data;
}

 

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


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

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

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

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

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

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

Войти

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

Войти

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

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

×

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

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