Magento

Produtos randômicos – Magento

Como criar uma listagem de produtos randômicos no Magento

Além da listagem randômica, irei ensinar como filtrar os produtos utilizando categorias.

1° – Preparando a “collection”

$_productCollection = Mage::getModel('catalog/product')->getCollection()
             ->addAttributeToSelect('*')
             ->addAttributeToFilter('status', 1)
             ->addAttributeToFilter('visibility', 4)  
             ->addStoreFilter();

Primeiro passo é a “collection” base que iremos utilizar para trazer nossos produtos.

Nela estou filtrando o status “habilitado” e a visibilidade 4, que significa “Catálogo e Busca”.

2° – Adicionando as categorias

Nessa primeira parte, estou preparando o array “conditions” com as condições para utilizar na nossa Query.

Repare que na variável “catfilters” estou passando um array com os IDs de cada categoria que será incluída na busca.

            $catfilters = array(1,20,32,44);
            $conditions = array();
            foreach ($catfilters as $categoryId) {
                if (is_numeric($categoryId)) {
                    $conditions[] = "{{table}}.category_id = $categoryId";
                }
            }

Segunda parte.

            $_productCollection->distinct(true)
                ->joinField('category_id', 'catalog/category_product', null, 'product_id = entity_id', implode(" OR ", $conditions), 'inner');        

Nesta segunda parte, estou utilizando o método “implode” com separador ” or “, para adicionar as categorias na condição dessa nossa “collection”.

Método “implode”, irá converter o array em uma unica string, separando cada elemento do array com ” or ” na string gerada.

3° – Definindo um limite e página para consulta.

 $_productCollection->setPageSize($limit)->setCurPage($page);

A variável “limit” no método “setPageSize” é a quantidade de registro que você deseja, já a “page” no método “setCurPage” é a página que será retornada, no caso você pode passar 1 para retornar os primeiros registros.

4° – Parte final, ordenando aleatoriamente.

$_productCollection->getSelect()->order(new Zend_Db_Expr('RAND()'));

Utilizando o método “order”, defino que a ordenação da minha consulta será randômica utilizando classe do Zend Framework “Zend_Db_Expr”, que trará a expressão correta.

Pronto, para percorrer os registros, basta utilizar um “foreach”, igual exemplo abaixo.

foreach ($_productCollection as $_product){

// $_product->getName()

// $_product->getProductUrl()

// Mage::helper('catalog/image')->init($_product, 'small_image')->resize(170) 

}

Os campos do produto você pode acessar diretamente no objeto “_product”.

No código tem alguns exemplos comentando.

Obs. Caso você não queira filtrar as categorias dos produtos randômicos, basta pular o passo 2°.

 

 

Resumo
Nome do Artigo
Como criar uma lista de Produtos randômicos no Magento
Descrição
Criando uma lista de Produtos randômicos no Magento e adicionando um filtro para buscar apenas os produtos de um determinado grupo de categorias
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás