Вам бонус- начислено 1 монета за дневную активность. Сейчас у вас 1 монета

Работаем с коллекцией продуктов (Product Collection) в Magento

Практика



Любой разработчик, который использует CMS Magento, рано или поздно вынужден погрузиться в коллекции моделей. Очень часто работать приходиться с коллекцией характеристик продукта (product resource collection). В этой статье разберем основы касаемо загрузки, фильтрации, сортировки и модификации данной коллекции.

 

Загрузка коллекции продуктов
Существует два основных способа загрузки коллекции продуктов. С помощью метода getCollection() из экземпляра модели продукта или загрузка класса коллекции с помощью фабричного метода getResourceModel().

Добавляем атрибуты к коллекции
Модель продукта – огромный набор данных. Чем больше атрибутов модели используется для выборки, тем дольше она будет выполняться. По умолчанию, с помощью вышеупомянутых способов CMS Magento загружает только основные данные, найденные в таблице

Для добавления всех атрибутов используют:

Для отдельных атрибутов:

Для специфичных атрибутов:

Добавляем ID категории к продуктам:

Многоуровневое ценообразование (tier pricing):

Добавляем URL Rewrites к продуктам:

Фильтруем результаты
Используя EAV тип сущностей системы, можно получить доступ к удивительному методу ‘addAttributeToFilter()’. Например:

также можно записать:

Этот метод используется как дополнение к стандартному методу ‘addFieldToFilter()’ из Zend-библиотеки Varien_Data_Collection_Db и принимает большое количество аргументов. Эти аргументы представлены в виде выражений и схожи по своей природе с запросами SQL. Приведем пример таких выражений в Magento и равноценного использования выборки данных (SQL) с ключевым словом ‘WHERE’:

Фильтр по текущему магазину (store):

Фильтр по текущему вебсайту (website):

Фильтр по категории:

Сортировка коллекции
Снова, как и в случае с SQL, вы можете отсортировать коллекцию по выбранному атрибуту в порядке возрастания или убывания.
Сортировка по возрастанию:

Сортировка по убыванию:

Случайный порядок:

Ограничение выборки
Если наступит ситуация в которой необходимо ограничить количество продуктов загружаемой коллекции, можно задействовать метод ‘setPageSize()’:

Количество продуктов
Всегда полезно проверять возвратились ли результаты после загрузки коллекции и сколько продуктов в коллекции:

 

Отладка коллекции
Хотите знать, почему и как коллекция выполняет возвращение результатов? Применяя метод ‘getSelect()’ для коллекции, вы можете вывести все запросы MySQL, которые отправляются в базу данных.

Классы коллекций моделей в Magento являются чрезвычайно мощными инструментами и существенно упрощают выполнение запросов и фильтрацию данных, даже без каких-либо знаний MySQL.

создано: 2018-10-26
обновлено: 2021-03-13
324



Рейтиг 9 of 10. count vote: 2
Вы довольны ?:


Поделиться:

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выплнения задания
  • Возможно примерение функции гаранта на сделку
  • Приорететная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можите продать(исполнителем) или купить(заказчиком) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно примерение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии


Оставить комментарий
Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend)

Термины: Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend)