整理的一些实用WordPress后台MySQL操作命令


Posted in PHP onJanuary 07, 2013

不过假设你的WordPress网站上有成百上千篇文章,而你需要进行全站范围的改动, 这时从后台逐条编辑就有点费时费力了,并且犯错的几率也会提高。 最好的方法是进入WordPress的MySQL数据库执行必要的查询(改动)。 通过MySQL可以迅速地完成以上任务,为你节省更多时间。

下面要介绍的就是一些省时省力的WordPress SQL查询方法。

事先备份
WordPress数据库里存储了你精心发表的每一篇文章,来自你的读者的所有评论,以及你对自己网站进行的所有个性化设置。 因此,无论你对自己有多自信,都请记住一定要事先备份WordPress数据库。 你可以通过备份插件进行备份。

为所有文章和页面添加自定义字段
这段代码可以为WordPress数据库内所有文章和页面添加一个自定义字段。 你需要做的就是把代码中的‘UniversalCutomField‘替换成你需要的文字,然后把‘MyValue‘改成需要的值。

INSERT INTO wp_postmeta (post_id, meta_key, meta_value) 
SELECT ID AS post_id, 'UniversalCustomField' 
AS meta_key 'MyValue AS meta_value FROM wp_postsWHERE ID NOT IN (SELECT post_id FROM wp_postmeta WHERE meta_key = 'UniversalCustomField');

如果只需要为文章添加自定义字段,可以使用下面这段代码:
INSERT INTO wp_postmeta (post_id, meta_key, meta_value) 
SELECT ID AS post_id, 'UniversalCustomField' 
AS meta_key 'MyValue AS meta_value 
FROM wp_posts WHERE ID NOT IN 
(SELECT post_id FROM wp_postmeta WHERE meta_key = 'UniversalCustomField')`` AND post_type = 'post';

如果只需要为页面添加自定义字段,可以使用下面这段代码:
INSERT INTO wp_postmeta (post_id, meta_key, meta_value) 
SELECT ID AS post_id, 'UniversalCustomField' 
AS meta_key 'MyValue AS meta_value 
FROM wp_posts WHERE ID NOT IN 
(SELECT post_id FROM wp_postmeta WHERE meta_key = 'UniversalCustomField')AND `post_type` = 'page';

删除文章meta数据
当你安装或删除插件时,系统通过文章meta标签存储数据。 插件被删除后,数据依然会存留在post_meta表中,当然这时你已经不再需要这些数据,完全可以删除之。 记住在运行查询前把代码里的‘YourMetaKey‘替换成你需要的相应值。
DELETE FROM wp_postmeta WHERE meta_key = 'YourMetaKey';

查找无用标签
如果你在WordPress数据库里执行查询删除旧文章,和之前删除插件时的情况一样,文章所属标签会留在数据库里,并且还会出现在标签列表/标签云里。 下面的查询可以帮你找出无用的标签。
SELECT * From wp_terms wtINNER JOIN wp_term_taxonomy wtt ON wt.term_id=wtt.term_id WHERE wtt.taxonomy='post_tag' AND wtt.count=0;

批量删除垃圾评论
执行以下SQL命令:
DELETE FROM wp_comments WHERE wp_comments.comment_approved = 'spam';

批量删除所有未审核评论
这个SQL查询会删除你的网站上所有未审核评论,不影响已审核评论。
DELETE FROM wp_comments WHERE comment_approved = 0

禁止评论较早文章
指定comment_status的值为open、closed或registered_only。
此外还需要设置日期(修改代码中的2010-01-01):
UPDATE wp_posts SET comment_status = 'closed' WHERE post_date < '2010-01-01' AND post_status = 'publish';

停用/激活trackback与pingback
指定comment_status的值为open、closed或registered_only。
向所有用户激活pingbacks/trackbacks:
UPDATE wp_posts SET ping_status = 'open';

向所有用户禁用pingbacks/trackbacks:
UPDATE wp_posts SET ping_status = 'closed';

激活/停用某一日期前的Pingbacks & Trackbacks
指定ping_status的值为open、closed或registered_only。
此外还需要设置日期(修改代码中的2010-01-01):
UPDATE wp_posts SET ping_status = 'closed' WHERE post_date < '2010-01-01' AND post_status = 'publish';

删除特定URL的评论
当你发现很多垃圾评论都带有相同的URL链接,可以利用下面的查询一次性删除这些评论。%表示含有“%"符号内字符串的所有URL都将被删除。
DELETE from wp_comments WHERE comment_author_url LIKE "%nastyspamurl%" ;

识别并删除“X"天前的文章
查找“X"天前的所有文章(注意把X替换成相应数值):
SELECT * FROM `wp_posts` WHERE `post_type` = 'post'AND DATEDIFF(NOW(), `post_date`) > X

删除“X"天前的所有文章:
DELETE FROM `wp_posts` WHERE `post_type` = 'post'AND DATEDIFF(NOW(), `post_date`) > X

删除不需要的短代码
当你决定不再使用短代码时,它们不会自动消失。你可以用一个简单的SQL查询命令删除所有不需要的短代码。 把“tweet"替换成相应短代码名称:
UPDATE wp_post SET post_content = replace(post_content, '[tweet]', '' ) ;

将文章转为页面
依然只要通过PHPMyAdmin运行一个SQL查询就可以搞定:
UPDATE wp_posts SET post_type = 'page' WHERE post_type = 'post'

将页面转换成文章:
UPDATE wp_posts SET post_type = 'post' WHERE post_type = 'page'

更改所有文章上的作者属性
首先通过下面的SQL命令检索作者的ID:
SELECT ID, display_name FROM wp_users;

成功获取该作者的新旧ID后,插入以下命令,记住用新作者ID替换NEW_AUTHOR_ID,旧作者ID替换OLD_AUTHOR_ID。
UPDATE wp_posts SET post_author=NEW_AUTHOR_ID WHERE post_author=OLD_AUTHOR_ID;

批量删除文章修订历史
文章修订历史保存可以很实用,也可以很让人烦恼。 你可以手动删除修订历史,也可以利用SQL查询给自己节省时间。
DELETE FROM wp_posts WHERE post_type = "revision";

停用/激活所有WordPress插件
激活某个插件后发现无法登录WordPress管理面板了,试试下面的查询命令吧,它会立即禁用所有插件,让你重新登录。
UPDATE wp_options SET option_value = 'a:0:{}' WHERE option_name = 'active_plugins';

更改WordPress网站的目标URL
把WordPress博客(模板文件、上传内容&数据库)从一台服务器移到另一台服务器后,接下来你需要告诉WordPress你的新博客地址。
使用以下命令时,注意将http://www.old-site.com换成你的原URL,http://blog.doucube.com换成新URL地址。
首先:
UPDATE wp_options 
SET option_value = replace(option_value, 'http://www.old-site.com', 'http://blog.doucube.com') 
WHERE option_name = 'home' OR option_name = 'siteurl';

然后利用下面的命令更改wp_posts里的URL:
UPDATE wp_posts SET guid = replace(guid, 'http://www.old-site.com','http://blog.doucube.com);

最后,搜索文章内容以确保新URL链接与原链接没有弄混:
UPDATE wp_posts SET post_content = replace(post_content, ' http://www.ancien-site.com ', ' http://blog.doucube.com ');

更改默认用户名Admin
把其中的YourNewUsername替换成新用户名。
UPDATE wp_users SET user_login = 'YourNewUsername' WHERE user_login = 'Admin';

手动重置WordPress密码
如果你是你的WordPress网站上的唯一作者,并且你没有修改默认用户名, 这时你可以用下面的SQL查询来重置密码(把其中的PASSWORD换成新密码):
UPDATE `wordpress`.`wp_users` SET `user_pass` = MD5('PASSWORD') 
WHERE `wp_users`.`user_login` =`admin` LIMIT 1;

搜索并替换文章内容
OriginalText换成被替换内容,ReplacedText换成目标内容:
UPDATE wp_posts SET `post_content` = REPLACE (`post_content`, 'OriginalText','ReplacedText');

更改图片URL
下面的SQL命令可以帮你修改图片路径:
UPDATE wp_postsSET post_content = REPLACE (post_content, 'src="http://www.myoldurl.com', 'src="http://blog.doucube.com');
PHP 相关文章推荐
php 向访客和爬虫显示不同的内容
Nov 09 PHP
php mssql扩展SQL查询中文字段名解决方法
Oct 15 PHP
解析PHP正则提取或替换img标记属性
Jun 26 PHP
解决file_get_contents无法请求https连接的方法
Dec 17 PHP
WordPress中获取页面链接和标题的相关PHP函数用法解析
Dec 17 PHP
php中的登陆login实例代码
Jun 20 PHP
ThinkPHP和UCenter接口冲突的解决方法
Jul 25 PHP
php登录超时检测功能实例详解
Mar 21 PHP
PHP将身份证正反面两张照片合成一张图片的代码
Apr 08 PHP
Laravel 实现密码重置功能
Feb 23 PHP
php 字符串中是否包含指定字符串的多种方法
Apr 12 PHP
PHP RabbitMQ消息列队
May 11 PHP
PHP中设置时区,记录日志文件的实现代码
Jan 07 #PHP
PHP基础教程(php入门基础教程)一些code代码
Jan 06 #PHP
将博客园(cnblogs.com)数据导入到wordpress的代码
Jan 06 #PHP
PHP表单递交控件名称含有点号(.)会被转化为下划线(_)的处理方法
Jan 06 #PHP
Fine Uploader文件上传组件应用介绍
Jan 06 #PHP
PDO版本问题 Invalid parameter number: no parameters were bound
Jan 06 #PHP
PHPEXCEL 使用小记
Jan 06 #PHP
You might like
PHP 变量类型的强制转换
2009/10/23 PHP
PHP中通过语义URL防止网站被攻击的方法分享
2011/09/08 PHP
PHP的可变变量名的使用方法分享
2012/02/05 PHP
关于crontab的使用详解
2013/06/24 PHP
php实现根据IP地址获取其所在省市的方法
2015/04/30 PHP
PHP面向对象详解(三)
2015/12/07 PHP
PHP全局变量与超级全局变量区别分析
2016/04/01 PHP
php 中phar包的使用教程详解
2018/10/26 PHP
解决extjs在firefox中关闭窗口再打开后iframe中js函数访问不到的问题
2008/11/06 Javascript
js获取select标签选中值的两种方式
2014/01/09 Javascript
使用JavaScript 实现的人脸检测
2015/03/24 Javascript
PhantomJS快速入门教程(服务器端的 JavaScript API 的 WebKit)
2015/08/06 Javascript
jQuery简单实现仿京东商城的左侧菜单效果代码
2015/09/09 Javascript
JS实现鼠标框选效果完整实例
2016/06/20 Javascript
JavaScript实现简单的星星评分效果
2017/05/18 Javascript
AngularJS 购物车全选/取消全选功能的实现方法
2017/08/14 Javascript
Vue仿手机qq的实例代码(demo)
2017/09/08 Javascript
JS写XSS cookie stealer来窃取密码的步骤详解
2017/11/20 Javascript
jQuery实现的五星点评功能【案例】
2019/02/18 jQuery
Vue.js轮播图走马灯代码实例(全)
2019/05/08 Javascript
javascript实现导航栏分页效果
2019/06/27 Javascript
vue实现配置全局访问路径头(axios)
2019/11/01 Javascript
Python 可爱的大小写
2008/09/06 Python
Python实现的飞速中文网小说下载脚本
2015/04/23 Python
python读取图片并修改格式与大小的方法
2018/07/24 Python
python利用wx实现界面按钮和按钮监听和字体改变的方法
2019/07/17 Python
Python 如何创建一个简单的REST接口
2020/07/30 Python
python飞机大战游戏实例讲解
2020/12/04 Python
世界最大的私人旅行指南出版商:孤独星球
2016/08/23 全球购物
跑步爱好者一站式服务网站:Jack Rabbit
2016/09/01 全球购物
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
编辑找工作求职信范文
2013/12/16 职场文书
李白故里导游词
2015/02/12 职场文书
2015年社区纪检工作总结
2015/04/21 职场文书
创业计划书之闲置物品置换中心
2019/12/25 职场文书
联想win10摄像头打不开怎么办?win10笔记本摄像头打不开解决办法
2022/04/08 数码科技