Como executar um Query no WordPress utilizando o objeto global “wpdb”.
Irei listar alguns exemplos com diversos tipos de Querys.
Um “select” retornando múltiplas linhas.
global $wpdb; $tableName = "tabela_teste"; $result = $wpdb->get_results("SELECT * FROM $tableName"); foreach ($result as $row) { echo '' .$row->coluna_teste. '
'; }
Quando o resultado esperado for apenas 1 linha, utilize o exemplo abaixo:
global $wpdb; $query = "SELECT * FROM `tba_teste` WHERE id = 1"; $row = $wpdb->get_row($query, ARRAY_A); echo ""; print_r($row); echo "";
Exemplo de Insert:
global $wpdb; $query = " INSERT INTO teste (name) values ('test') " $wpdb->query( $query ); /* ID do registro que acabou de ser inserido. */$lastid = $wpdb->insert_id;
Para Update:
global $wpdb; $query = " UPDATE teste SET name = 'test' WHERE id = 1 " $wpdb->query( $query );
Ainda para UPDATE, você pode utilizar esta função exclusiva do WordPress:
$wpdb->update( $table, $data, $where, $format = null, $where_format = null );
Exemplo de parâmetros para função acima:
$wpdb->update( 'nome_da_tabela', array( 'coluna_01' => 'valor_01', 'coluna_02' => 'valor_02' ), array( 'id' => 1 ), array( '%s', '%d' ), array( '%d' ) );
Para Delete:
global $wpdb; $query = " DELETE FROM teste WHERE id = 1 " $wpdb->query( $query );
Delete também possuí uma função própria no WordPress.
$wpdb->delete( $table, $where, $where_format = null );
Exemplo com parâmetros.
$wpdb->delete( 'nome_da_tabela', array( 'id' => 1 ) );
Utilize sempre o método “$wpdb->prepare” para evitar ataque em suas consultas.
O método “prepare” irá remover qualquer SQL que esteja no valor das variáveis que estão sendo utilizadas na Query.
Exemplos:
$result = $wpdb->query($wpdb->prepare("UPDATE tabela_de_teste SET name = 'Roger' WHERE id = %d", $id));
$sql = $wpdb->prepare( "SELECT * FROM %s ORDER BY id DESC",$nome_da_tabela);
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…
Ver comentários
Me ajudou muito! Valeu!
Vlw pela dica, como faço para executar isso em um arquivo na raiz do site? Exemplo: cad-post.php
estou desenvolvendo uma integração porém não quero fazer um plugin para isso,
Mario, muito obrigado pelo comentário.
Você terá que carregar o arquivo wp-load.php antes do código utilizando a função include.
Após isso você poderá executar qualquer função disponível no wordpress.