Como montar uma query no Magento e executa-la utilizando os recursos nativos da própria plataforma.
Nada de “models”, apenas o SQL.
Vamos direto ao ponto.
$resource = Mage::getSingleton('core/resource'); $readConnection = $resource->getConnection('core_read');
No código acima, primeiro pegamos a instancia da classe “core/resource” e com método “getConnection” iremos ter acesso a conexão de leitura passando como parâmetro o valor ‘core_read'.
$query = ' SELECT col1 FROM tabela_test LIMIT 1 '; $one_result = $readConnection->fetchCol( $query );
Acima montamos um query de teste e a executamos com método “fetchCol”, utilizamos essa função pois queremos apenas a primeira coluna das linhas resultantes.
Podemos utilizar também “fetchAll”, para trazer várias linhas e todas as colunas da query.
$results = $readConnection->fetchAll( $query );
Você poderá percorrer cada linha retornada com “foreach” na variável “results”.
Caso você queira retornar apenas 1 linha e 1 coluna, utilize o método a seguir:
$result = $readConnection->fetchOne($query);
A função “fetchOne” irá retornar imediatamente o valor da coluna na variável “result”.
$resource = Mage::getSingleton('core/resource'); $writeConnection = $resource->getConnection('core_write');
Utilizamos a mesma instancia anterior “core/resource”, mudando apenas o parâmetro no “getConnection” para “core_write”, pois iremos fazer uma inserção “escrita” no banco.
$query = " INSERT INTO test (ab,cd) VALUES ('ab','cd'); "; $writeConnection->query($query)
Com método “query” em nosso objeto executamos nossa query.
Dá mesma forma que o “insert”, iremos utilizar “core_write” invés do “core_read”.
$resource = Mage::getSingleton('core/resource'); $writeConnection = $resource->getConnection('core_write');
$query = " UPDATE test SET name = 'test' WHERE id = 1 "; $writeConnection->query($query);
$query = " DELETE FROM test WHERE id = 1 "; $writeConnection->query($query);
Muito cuidado ao executar essas query, aconselho a você sempre estar utilizando os “models”, pois eles irão padronizar o seu código e ajudarão a proteger suas consultas.
Contudo em algumas situações e necessário executar uma consulta complexa ou algo do tipo, neste caso nunca se esqueça de validar os parâmetros utilizados na sua query, evitando “SQL Injection”.
Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…
Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…
Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…
Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…
Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…
Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…