Сегодня будет достаточно практическая публикация, в которой мы приведем несколько готовых полезных примеров sql-запросов, позволяющих очистить или оптимизировать базу данных вашего сайта на WordPress.
В первую очередь перед любыми действиями с базой данных необходимо сделать бэкап (резервную копию). Для создания резервной копии базы данных сайтов, расположенных на нашем хостинге — достаточно зайти в вашу хостинг-панель в раздел «Базы данных» и воспользоваться кнопкой «Загрузить/Скачать».
Так вы сможете скопировать себе на компьютер sql-файл, в котором содержатся все данные из базы данных сайта. При необходимости вы всегда можете восстановить базу WordPress сайта из этого файла.
Итак переходим к конкретике. Заметьте, во всех командах текст MYPREFIX_ нужно изменить на актуальный префикс ваших таблиц в базе данных, например на wp_ (этот префикс используется часто по умолчанию).
UPDATE `MYPREFIX_users` SET `user_pass` = MD5( 'новий_пароль' ) WHERE `MYPREFIX_users`.`user_login` = "логин_админа";
Вместо слова «новий_пароль» нужно указать новый пароль, а вместо «логин_админа» — логин пользователя, пароль которого будет изменен.
UPDATE MYPREFIX_options SET option_value = 'twentynineteen' WHERE option_name = 'template' or option_name = 'stylesheet';
Измените twentynineteen на название шаблона, который надо сделать активным.
UPDATE MYPREFIX_options SET option_value = '' WHERE option_name = 'active_plugins';
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '“', '“');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, 'â€', '”');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '’', '’');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '‘', '‘');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '—', '–');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '–', '—');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '•', '-');
UPDATE MYPREFIX_comments SET comment_content = REPLACE(comment_content, '…', '…');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '“', '“');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, 'â€', '”');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '’', '’');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '‘', '‘');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '—', '–');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '–', '—');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '•', '-');
UPDATE MYPREFIX_posts SET post_content = REPLACE(post_content, '…', '…');
Данные команды изменят указаны «непонятные» символы в тексте публикаций и комментариях на их «понятный» аналог.
DELETE FROM MYPREFIX_comments WHERE comment_approved = 'spam';
UPDATE MYPREFIX_posts SET post_content = replace(post_content, 'http://yoursite.com', 'https://yoursite.com');
Данная команда изменит ссылки http://yoursite.com на https://yoursite.com в тексте публикаций.
DELETE FROM `MYPREFIX_posts`
WHERE `post_type` = 'post'
AND DATEDIFF(NOW(), `post_date`) > 10
Измените цифру 10 в конце на нужное количество дней.
DELETE FROM MYPREFIX_postmeta WHERE meta_key = 'YourMetaKey';
UPDATE MYPREFIX_posts SET ping_status = 'closed';
DELETE a,b,c FROM MYPREFIX_posts a WHERE a.post_type = 'revision' LEFT JOIN MYPREFIX_term_relationships b ON (a.ID = b.object_id) LEFT JOIN MYPREFIX_postmeta c ON (a.ID = c.post_id);
DELETE FROM MYPREFIX_terms WHERE term_id IN (SELECT term_id FROM MYPREFIX_term_taxonomy WHERE count = 0 );
DELETE FROM MYPREFIX_term_taxonomy WHERE term_id not IN (SELECT term_id FROM MYPREFIX_terms);
DELETE FROM MYPREFIX_term_relationships WHERE term_taxonomy_id not IN (SELECT term_taxonomy_id FROM MYPREFIX_term_taxonomy);