zomo Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Доброе время суток господа, очень нужна помощь необходимо создать список категорий с кол-во товаров в них причем при кешировании это должен быть один файл кеша... проблема с последним условием. мои мысли $results = $this->model_product_category->getCategories(); $filter_data = array( 'filter_category_id' => $result['product_category_id'], ); $total_products = $this->model_catalog_product->getTotalProducts($filter_data); } Это дело все работает, но есть НО( в модели оно кешируется кучей файлов, так как $total_products дергается по всем категориям... нужно создать один файл кеша в котором были бы пары category_id = 34; product_total = 5; и тд Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Добрый день. Надо делать свой запрос в модели. Что-то вроде этого: SELECT c.category_id, COUNT(p2c.product_id) AS total FROM `category` c LEFT JOIN `product_to_category` p2c ON (c.category_id = p2c.category_id) GROUP BY c.category_id И кэшировать уже результат этого запроса. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Ещё один вариант запроса: SELECT c.category_id, (SELECT COUNT(*) FROM `product_to_category` p2c WHERE p2c.category_id = c.category_id) AS total FROM `category` c Нет большой базы под рукой, чтобы проверить какой запрос будет быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 На вскидку второй вариант должен быть быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 При создании массива для кэширования, category_id лучше сделать индексом, а в значение писать количество товаров. Чтобы сразу по индексу (category_id) из массива вытянуть количество товаров. Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Допомога програмістам та розробникам Получить кол-во товаров во всех категориях Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich × Уже зареєстровані? Ввійти Реєстрація Ваші замовлення Назад Придбані модулі та шаблони Ваші рахунки Лист очікувань Альтернативні контакти Форум Новини ocStore Назад Офіційний сайт Демо ocStore 3.0.3.2 Демо ocStore 2.3.0.2.4 Завантажити ocStore Документація Історія версій ocStore Блоги Модулі Шаблони Назад Безкоштовні шаблони Платні шаблони Де купувати модулі? Послуги FAQ OpenCart.Pro Назад Демо Купити Порівняння × Створити... Important Information На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність. Я даю згоду
mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Добрый день. Надо делать свой запрос в модели. Что-то вроде этого: SELECT c.category_id, COUNT(p2c.product_id) AS total FROM `category` c LEFT JOIN `product_to_category` p2c ON (c.category_id = p2c.category_id) GROUP BY c.category_id И кэшировать уже результат этого запроса. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Ещё один вариант запроса: SELECT c.category_id, (SELECT COUNT(*) FROM `product_to_category` p2c WHERE p2c.category_id = c.category_id) AS total FROM `category` c Нет большой базы под рукой, чтобы проверить какой запрос будет быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 На вскидку второй вариант должен быть быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 При создании массива для кэширования, category_id лучше сделать индексом, а в значение писать количество товаров. Чтобы сразу по индексу (category_id) из массива вытянуть количество товаров. Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Допомога програмістам та розробникам Получить кол-во товаров во всех категориях Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich
mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 Ещё один вариант запроса: SELECT c.category_id, (SELECT COUNT(*) FROM `product_to_category` p2c WHERE p2c.category_id = c.category_id) AS total FROM `category` c Нет большой базы под рукой, чтобы проверить какой запрос будет быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 На вскидку второй вариант должен быть быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 При создании массива для кэширования, category_id лучше сделать индексом, а в значение писать количество товаров. Чтобы сразу по индексу (category_id) из массива вытянуть количество товаров. Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Допомога програмістам та розробникам Получить кол-во товаров во всех категориях
mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 На вскидку второй вариант должен быть быстрее. Надіслати Поділитися на інших сайтах More sharing options... mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 При создании массива для кэширования, category_id лучше сделать индексом, а в значение писать количество товаров. Чтобы сразу по индексу (category_id) из массива вытянуть количество товаров. Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку
mpn2005 Опубліковано: 10 червня 2019 Share Опубліковано: 10 червня 2019 При создании массива для кэширования, category_id лучше сделать индексом, а в значение писать количество товаров. Чтобы сразу по индексу (category_id) из массива вытянуть количество товаров. Надіслати Поділитися на інших сайтах More sharing options... Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0
Recommended Posts