SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 в модели категории, но не суть. почитай уже топик 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 { Да и вот тоже.. Надіслати Поділитися на інших сайтах More sharing options... freelancer Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $categories = $this->model_catalog_category->getCategoriesByParentId я устал спорить 1 Надіслати Поділитися на інших сайтах More sharing options... SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 freelancer, *** стыд, ну а где вызывается вы видите? И почему и зачем она вызывается вы понимаете? А теперь сначала, вызывается для того, чтобы подтянуть товары из дочерних категорий, находясь мы в родительской. А если галки будут ставиться автоматом, то не придется _искать_ дочерние категории, они уже будут известны в таблице product_to_category. Надіслати Поділитися на інших сайтах More sharing options... SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 В некоторых местах так даже удобнее, но это в основном применимо в админке... В паблике зачастую требуется получить полное дерево категорий, например для меню типа superfish... и тогда лучше рекурсивно трепать массив, а не базу. Это для админки вообще-то и делалось. Смотрите по какому принципу проставляются категории.. Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так? А зачем это делать? Я приводил пример для чего это надо - superfish.Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет... Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Загальні питання Жуткие тормоза (100 категорий , 10 000 товаров) Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень 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 і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність. Я даю згоду
freelancer Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $categories = $this->model_catalog_category->getCategoriesByParentId я устал спорить 1 Надіслати Поділитися на інших сайтах More sharing options... SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 freelancer, *** стыд, ну а где вызывается вы видите? И почему и зачем она вызывается вы понимаете? А теперь сначала, вызывается для того, чтобы подтянуть товары из дочерних категорий, находясь мы в родительской. А если галки будут ставиться автоматом, то не придется _искать_ дочерние категории, они уже будут известны в таблице product_to_category. Надіслати Поділитися на інших сайтах More sharing options... SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 В некоторых местах так даже удобнее, но это в основном применимо в админке... В паблике зачастую требуется получить полное дерево категорий, например для меню типа superfish... и тогда лучше рекурсивно трепать массив, а не базу. Это для админки вообще-то и делалось. Смотрите по какому принципу проставляются категории.. Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так? А зачем это делать? Я приводил пример для чего это надо - superfish.Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет... Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Загальні питання Жуткие тормоза (100 категорий , 10 000 товаров) Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень 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 і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність. Я даю згоду
SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 freelancer, *** стыд, ну а где вызывается вы видите? И почему и зачем она вызывается вы понимаете? А теперь сначала, вызывается для того, чтобы подтянуть товары из дочерних категорий, находясь мы в родительской. А если галки будут ставиться автоматом, то не придется _искать_ дочерние категории, они уже будут известны в таблице product_to_category. Надіслати Поділитися на інших сайтах More sharing options... SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 В некоторых местах так даже удобнее, но это в основном применимо в админке... В паблике зачастую требуется получить полное дерево категорий, например для меню типа superfish... и тогда лучше рекурсивно трепать массив, а не базу. Это для админки вообще-то и делалось. Смотрите по какому принципу проставляются категории.. Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так? А зачем это делать? Я приводил пример для чего это надо - superfish.Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет... Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Загальні питання Жуткие тормоза (100 категорий , 10 000 товаров) Покупцям Оплата розширень фізичними особами Оплата розширень юридичними особами Політика повернень Розробникам Регламент розміщення розширень Регламент продажу та підтримки розширень Віртуальний обліковий запис автора Політика просування оголошень API каталогу розширень Вирішення спорів щодо авторських прав Корисна інформація Публічна оферта Політика повернень Політика конфіденційності Платіжна політика Політика передачі особистих даних Політика прозорості Останні розширення Повний пакет SEO Автор: GeekoDev SameSite Session Fix Opencart 3 Автор: web_bond SP Telegram повідомлення FREE Автор: spectre Відключити порожні категорії Автор: spectre SEO Автор тексту категорії / фільтра / блогу з датою оновлення контенту + мікророзмітка Автор: radaevich
SooR Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 В некоторых местах так даже удобнее, но это в основном применимо в админке... В паблике зачастую требуется получить полное дерево категорий, например для меню типа superfish... и тогда лучше рекурсивно трепать массив, а не базу. Это для админки вообще-то и делалось. Смотрите по какому принципу проставляются категории.. Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так? А зачем это делать? Я приводил пример для чего это надо - superfish.Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет... Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку Последние темы Последние дополнения Последние новости Вся активність Головна Підтримка та відповіді на запитання. Загальні питання Жуткие тормоза (100 категорий , 10 000 товаров)
Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 Так, секундочку, дерево для чего? Для вытяжки товаров из дочерних категорий, так? А зачем это делать? Я приводил пример для чего это надо - superfish.Если этого мало - добавлю: генератор сайтмэп, выгрузка в Яндекс.Маркет... Надіслати Поділитися на інших сайтах More sharing options... Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0 Перейти до списку тем Зараз на сторінці 0 користувачів Ні користувачів, які переглядиють цю сторінку
Yesvik Опубліковано: 8 грудня 2011 Share Опубліковано: 8 грудня 2011 $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 Надіслати Поділитися на інших сайтах More sharing options... Назад 1 2 3 Вперед Сторінка 3 з 3 Створіть аккаунт або увійдіть для коментування Ви повинні бути користувачем, щоб залишити коментар Створити обліковий запис Зареєструйтеся для отримання облікового запису. Це просто! Зареєструвати аккаунт Вхід Уже зареєстровані? Увійдіть тут. Вхід зараз Share More sharing options... Передплатники 0
Recommended Posts