Programação

Treino e Dedicação. Habilidade e Presteza com Atenção.

Dicas de comandos SQL mais avançados do WordPress para desenvolderores

27/05/2015 às 20:25:00 Evaldo Lopes php, mysql, wordpress, banco de dados, programação web 01 Comentário

Para quem faz uso um pouco mais avançado do WordPress, especialmente quem trabalha desenvolvendo sites com a plataforma, é bem comum aparecerem situações um tanto complexas.

Leia mais...

Dicas de comandos SQL mais avançados do WordPress para desenvolderores

27/05/2013 às 12:27:16 Evaldo Lopes sql, mysql, wordpress, banco de dados

Para quem faz uso um pouco mais avançado do WordPress, especialmente quem trabalha desenvolvendo sites com a plataforma, é bem comum aparecerem situações um tanto complexas.

Para estas questões, vai aqui algumas dicas de comandos SQL para WordPress!

Lembre-se: é sempre bom fazer um backup completo de seu banco de dados antes de executar queries SQL (principalmente se você não souber muito bem o que está fazendo)!
Este é um artigo traduzido do original “13 Useful WordPress SQL Queries You Wish You Knew Earlier“, do blog Onextrapixel, e sofreu algumas adaptações.

Uma maneira prática de executar comandos SQL é através do phpMyAdmin. Até a hospedagem mais básica dá acesso à ferramenta de banco de dados, então não há dificuldades nisso. Uma vez no sistema, você deve selecionar aba “SQL” e escrever/colar a instrução SQL que deseja executar.

phpmyadmin
Os comandos SQL para WordPress a seguir são para o prefixo padrão do WordPress “wp_”. Caso o prefixo de suas tabelas seja diferente (o que é recomendado, por questões de segurança), faça os devidos complementos necessários às queries.

1. Alterar siteurl e homeurl

WordPress armazena o caminho absoluto da URL do site (“siteurl”) e URL da home (“homeurl”) no banco de dados. Portanto, se você transferir o seu site WordPress do localhost para o servidor, por exemplo, o site não vai carregar! Isso ocorre porque o caminho absoluto ainda está apontando para o seu localhost. Você vai precisar executar um comando para resolver isso.
UPDATE wp_options

SET option_value = replace(option_value, ''http://www.enderecoantigo.com'',

''http://www.endereconovo.com'')

WHERE option_name = ''home''

OR option_name = ''siteurl'';

 

2. Alterar GUID


Depois de migrar seu blog a partir de, por exemplo, localhost, para o servidor ou de um outro domínio para um novo domínio, você terá que corrigir as URLs para o campo GUID na tabela wp_posts. Isto é crucial, porque GUID é usado para montar o slug de seu post do caminho absoluto do artigo correto.
UPDATE wp_posts

SET guid = REPLACE (guid, ''http://www.enderecoantigo.com'', ''http://www.endereconovo.com'');

 

3. Alterar URL no conteúdo


O WordPress utiliza caminhos absolutos no URL ao invés de um caminho relativo quando vai armazená-los no banco de dados. Dentro do conteúdo de cada registro de artigo, ele armazena todas as URLs antigas referenciando as fontes antigas. Portanto, você precisará alterar todas essas URLs com o endereço do novo domínio.
UPDATE wp_posts

SET post_content = REPLACE (

post_content, ''http://www.enderecoantigo.com'',http://www.endereconovo.com'' );

4. Alterar apenas o caminho das imagens


Caso seja preciso alterar o domínio das imagens inseridas nas páginas e artigos, esta solução vai ajudar você a fazer isso de forma simples.
UPDATE wp_posts

SET post_content = REPLACE (

post_content, ''src="http://www.enderecoantigo.com'', ''src="http://www.endereconovo.com'' );

Também é preciso atualizar o GUID para o tipo “attachment” com a seguinte instrução SQL:
UPDATE wp_posts

SET guid = REPLACE (guid, ''http://www.enderecoantigo.com'', ''http://www.endereconovo.com'')

WHERE post_type = ''attachment'';

 

5. Atualizar Post Meta

Atualizar Post Meta funciona quase da mesma maneira como atualizar a URL no conteúdo do post. Se você tiver dados extras para cada post, você pode usar a seguinte instrução para alterar todos eles.
UPDATE wp_postmeta

SET meta_value = REPLACE (

meta_value, ''http://www.enderecoantigo.com'',''http://www.endereconovo.com'' );

 

6. Alterar o nome usuário padrão “admin”


Apesar de que na versão 3 do WordPress o usuário “admin” poderá ser alterado no momento da instalação, não custa deixar para a posteridade a dica de como alterar o nome do “admin”.
UPDATE wp_users

SET user_login = ''nomequevocequiser''

WHERE user_login = ''Admin'';

 

7. Resetar password


Já quis resetar sua senha no WordPress mas, por algum motivo, não conseguiu usar a seção para resetar o password? Eis a solução:
UPDATE wp_users

SET user_pass = MD5(''senha'')

WHERE user_login = ''login'';

 

8. Transferir artigos de um autor para outro


Para transferir os artigos de um autor para outro, você gasta um tempo enorme se fizer isso manualmente. Com o comando SQL a seguir, é possível fazer isso facilmente. Para a dica, é preciso saber o ID dos autores.
UPDATE wp_posts

SET post_author = ''id_novo_autor''

WHERE post_author = ''id_autor_antigo'';

9. Apagar revisões


Quando se está editando um artigo no WordPress, é comum cópias de segurança serem feitas para garantir o trabalho feito. São as chamadas “revisões”. Com o tempo, o número de registros de revisões fica grande e isso pode comprometer a performance do banco de dados. Para apagar todas as revisões de artigos, dê o seguinte comando SQL:
DELETE a,b,c FROM wp_posts a

LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)

LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)

WHERE a.post_type = ''revision''

Lembrando que este é o comando para apagar revisões já feitas. Caro queira desativar o recurso (ou limitar o número de revisões), saiba como neste artigo sobre como limitar e desativar revisões de posts no WordPress.

 

10. Apagar post meta


Instalar e remover plugins é algo corriqueiro quando se trabalha com WordPress. Alguns plugins precisam de criar alguns post meta para funcionarem corretamente e, para esses casos, não é raro o acontecimento de, mesmo depois de o plugin ser desinstalado, algum “garbage meta” ficar enchendo o BD desnecessariamente. Uma limpeza em algum valor de post meta, às vezes, se faz necessária.
DELETE FROM wp_postmeta

WHERE meta_key = ''nome-chave-meta'';

 

11. Exportar todos os e-mails de comentários


Quanto mais tempo seu blog/site fica no ar, é provável que mais comentários receba nos artigos publicados. Se, por algum motivo, for preciso uma listagem com e-mail de todas as pessoas que já comentaram até então, basta executar o seguinte comando:
SELECT DISTINCT comment_author_email

FROM wp_comments;

Uma vez que a listagem esteja concluída, exporte tudo através do phpMyAdmin.

 

12. Apagar todos pingbacks


A medida que o site/blog fica no ar – e se você tiver bom conteúdo a oferecer – o número de pingbacks começa a influenciar a qualidade do banco de dados. Para apagar todos pingbacks, proceda da seguinte maneira:
DELETE FROM wp_comments WHERE comment_type = ''pingback'';

 

13. Apagar todos comentários de SPAM

Sem maiores explicações, eis a maneira de deletar todos os comentários marcados como SPAM:
DELETE FROM wp_comments

WHERE comment_approved = ''spam'';

14. Identificar tags não usadas

Num banco de dados WordPress, se você executar alguma query SQL para apagar posts, as tags relacionadas não serão apagadas e continuarão aparecendo na nuvem de sugestão de tags e listagem de tags. Para identificar esse tipo de tag, execute a seguinte instrução SQL:
SELECT * From wp_terms wt

INNER JOIN wp_term_taxonomy wtt

ON wt.term_id=wtt.term_id

WHERE wtt.taxonomy=''post_tag''

AND wtt.count=0;
Lembre-se: é sempre bom fazer um backup completo de seu banco de dados antes de executar queries SQL (principalmente se você não souber muito bem o que está fazendo)!

Leia mais...

Concatenando resultados em uma coluna no MySql com o GROUP_CONCAT

20/09/2016 às 11:28:07 Evaldo Lopes sql, mysql

Olá! Certo dia precisei listar códigos "filhos" agrupados em referencia ao "pai", mas não de forma em linhas, mas sim os códigos "filhos" agrupados colunar. Tipo de tabela N-N. Entendam no exemplo: mysql> SELECT DISTINCT -> parent_id, child_id -> FROM group_c -> ORDER BY parent_id; +-----------+----------+ | parent_id | child_id | +-----------+----------+ | 1 | 1 | | 1 | 2 | | 1 | 3 | | 1 | 4 | | 2 | 1 | | 2 | 3 | | 2 | 4 | | 2 | 6 | | 3 | 1 | | 3 | 2 | | 4 | 1 | | 5 | 0 | +-----------+----------+ 12 rows in set (0.00 sec) Para isso utilizei o seguinte query string sql: mysql> SELECT DISTINCT -> parent_id, GROUP_CONCAT(DISTINCT child_id ORDER BY child_id) AS child_id_list -> FROM group_c -> group by parent_id -> ORDER BY parent_id; +-----------+---------------+ | parent_id | child_id_list | +-----------+---------------+ | 1 | 1,2,3,4 | | 2 | 1,3,4,6 | | 3 | 1,2 | | 4 | 1 | | 5 | 0 | +-----------+---------------+ 5 rows in set (0.00 sec) Por padrão, serão agrupados os child_id_list por vírgula. Mas podemos manipular o separador dessa forma: mysql> SELECT DISTINCT -> parent_id, GROUP_CONCAT(DISTINCT child_id ORDER BY child_id SEPARATOR '|') AS child_id_list -> FROM group_c -> group by parent_id -> ORDER BY parent_id; +-----------+---------------+ | parent_id | child_id_list | +-----------+---------------+ | 1 | 1,2,3,4 | | 2 | 1,3,4,6 | | 3 | 1,2 | | 4 | 1 | | 5 | 0 | +-----------+---------------+ 5 rows in set (0.00 sec)

Leia mais...

"Senhor eu sei que Tu me sondas, sei também que me conheces...
Senhor! eu que Tu me sondas..."