Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Жуткие тормоза (100 категорий , 10 000 товаров)


KingCrimson

Recommended Posts

в модели категории, но не суть.

почитай уже топик

if (!empty($data['filter_category_id'])) {
				if (!empty($data['filter_sub_category'])) {
					$implode_data = array();
					
					$implode_data[] = "p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
					
					$this->load->model('catalog/category');
					
					$categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);
										
					foreach ($categories as $category_id) {
						$implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
					}
								
					$sql .= " AND (" . implode(' OR ', $implode_data) . ")";			
				} else {
					$sql .= " AND p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
				}
			}

Это что тогда?

В моделе категории тоже есть, но я сократил кол-во запросов до 36 в категории убрав этот блок

if (!empty($data['filter_sub_category'])) {
					$implode_data = array();
					
					$implode_data[] = "p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
					
					$this->load->model('catalog/category');
					
					$categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);
										
					foreach ($categories as $category_id) {
						$implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
					}
								
					$sql .= " AND (" . implode(' OR ', $implode_data) . ")";			
				} else {

Да и вот тоже..

Надіслати
Поділитися на інших сайтах

freelancer, *** стыд, ну а где вызывается вы видите? И почему и зачем она вызывается вы понимаете?

А теперь сначала, вызывается для того, чтобы подтянуть товары из дочерних категорий, находясь мы в родительской.

А если галки будут ставиться автоматом, то не придется _искать_ дочерние категории, они уже будут известны в таблице product_to_category.

Надіслати
Поділитися на інших сайтах

В некоторых местах так даже удобнее, но это в основном применимо в админке...

В паблике зачастую требуется получить полное дерево категорий, например для меню типа superfish... и тогда лучше рекурсивно трепать массив, а не базу.

Это для админки вообще-то и делалось. Смотрите по какому принципу проставляются категории..

Надіслати
Поділитися на інших сайтах

Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так?

А зачем это делать?

Я приводил пример для чего это надо - superfish.

Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет...

Надіслати
Поділитися на інших сайтах

$implode_data[] = "p2c.category_id = '" . (int)$data['filter_category_id'] . "'";

$this->load->model('catalog/category');

$categories = $this->model_catalog_category ->getCategoriesByParentId($data['filter_category_id']);

foreach ($categories as $category_id) {
	$implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
}

$sql .= " AND (" . implode(' OR ', $implode_data) . ")";
Если дотошно всё оптимизировать - то цикл в данном месте явно лишний...

$this->load->model('catalog/category');

$categories = $this->model_catalog_category ->getCategoriesByParentId($data['filter_category_id']);

$categories[] = (int)$data['filter_category_id'];

$sql .= " AND (p2c.category_id = '" . implode("' OR p2c.category_id = '", $categories) . "')";
  • +1 1
Надіслати
Поділитися на інших сайтах

Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз
  • Зараз на сторінці   0 користувачів

    • Ні користувачів, які переглядиють цю сторінку
×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.