数据库:MySQL实战;左链接;查询WordPress数据库中的文章内容
在1年前,我用学生价租了一个阿里云服务器(是真的便宜啊),自己在CentOS系统上用命令行搭了个WordPress的环境,开始了为期一个月使用自建博客的历程。
事实证明,博客在类似博客园这样的平台上写还是非常方便的!
- 不用自己优化后台,虽然WordPress已经足够傻瓜了,但是我还是太菜了
- 只有小贵的价格才能租到一个网速不慢+大小够用的服务器
之前考研没有工作没有收入,于是就狠下心不要了。重新捡起了长草很久的博客园。
今天,下了决心把以前的数据导出来,就有了以下的内容
1、把wordpress.sql文件导入mysql数据库
打开Mac的终端,进入MySQL操作界面:
mysql -u root -p
输入密码

(1)创建一个空的数据库
create database <name>;
(2)查看是否创建成功(注意这里的databases加了s)
show databases;

(3)进入wordpress数据库进行接下来的操作
use wordpress;

(4)设置数据库编码
set names utf8;
(5)导入数据(注意sql文件的路径)
source /Users/wordpress.sql;
2、分析WordPress数据库的表结构
(1)显示WordPress数据库
show tables;

(2)具体每个表里边存着什么信息呢?
| Tables_in_wordpress | - |
|---|---|
| wp_commentmeta | 评论的数据 |
| wp_comments | 评论的数据 |
| wp_links | 友情链接的数据 |
| wp_mgmlp_folders | 未知 |
| wp_options | WordPress系统选项、插件、主题 |
| wp_postmeta | 文章的数据 |
| wp_posts | 文章内容 |
| wp_term_relationships | 文章和目录对应关系 |
| wp_term_taxonomy | 未知 |
| wp_termmeta | 未知 |
| wp_terms | 目录和标签 |
| wp_usermeta | 用户的数据 |
| wp_users | 用户的数据 |
(3)这次我主要使用的表和数据如下:
wp_posts:ID、post_date(文章发布时间)、post_title(文章题目)、post_status(文章状态)、post_content(文章内容)
wp_term_relationships:object_id(对应文章ID)、term_taxonomy_id(对应term_id)
wp_terms:term_id、name(目录名称)
(4)在列出了文章的一些简要信息是,我发现有非常多的重复文章
原来wordpress发布文章时会自动保存一些草稿、修订版本等无用的文章数据。
经过查看,发现很多的文章状态(post_status)都是inherit,这些文章状态都具体是什么意思呢?
publish:已发布
inherit:修订版
draft:草稿
auto-draft:自动保存的草稿
(以上4中就是出现在我的数据库中的状态)此外还有:
pending:待审、trash:回收站、future:定时、private:私有
- 由于我的强迫症,我决定删掉所有状态是inherit的文章(字段需要有单引号哦)
delete from wp_posts where post_status='inherit';
2、终于要开始多表查询了
(1)先查出我需要转移的所有的文章
(因为是在终端中查看,所以如果直接打印文章内容,是非常难以看懂的,我尝试了一次,手动苦笑)
思路:查询文章ID、发布时间、题目、状态以及文章所属的目录
文章所属的目录是先使用文章ID去wp_term_relationships表查询对应目录的id,然后根据term_id去wp_terms表中查询目录实际的名称
select p.ID,p.post_date,p.post_title,p.post_status,t.name
from wp_posts as p
left join wp_term_relationships as tr on p.ID=tr.object_id
left join wp_terms as t on t.term_id=tr.term_taxonomy_id;

(2)最后一步根据文章ID去查看文章内容post_content
select post_content from wp_posts where ID=1;

然而可以从图片中看到,WordPress数据库中的文章内容存储的是html格式,并且有的图片用的是链接。
由于我之前的文章数量很少,并且没有什么图片,用以上方法还是可以的。
如果文章数目大,图片链接多,就必须要借助已经写好的工具了。
祝周末愉快!
3、删除数据库
drop database <name>;
数据库:MySQL实战;左链接;查询WordPress数据库中的文章内容的更多相关文章
- mysql数据库优化课程---12、mysql嵌套和链接查询
mysql数据库优化课程---12.mysql嵌套和链接查询 一.总结 一句话总结:查询user表中存在的所有班级的信息? in distinct mysql> select * from cl ...
- 1028阿里RDS如何恢复云数据库MySQL的备份文件到自建数据库
参照 https://help.aliyun.com/knowledge_detail/41817.html 恢复云数据库MySQL的备份文件到自建数据库 更新时间:2017-07-27 14:52: ...
- 如何用拉姆达表达式(Lambda Expressions) 书写左链接查询
在C#中,如果要实现两个列表的左链接查询,我们的一般用法就是用的linq表达式就是 List<Pet> pets = }, }, } }; List<Pet2> pets2 = ...
- 恢复云数据库MySQL的备份文件到自建数据库遇到的报错
报错信息 : 恢复云数据库MySQL的备份文件到自建数据库,自建数据库版本5.6.36. 按照阿里云文档操作,启动数据库报错 -- :: [ERROR] /application/mysql/bin/ ...
- 恢复阿里云RDS云数据库MySQL的备份文件到自建数据库
云数据库MySQL版使用开源软件Percona Xtrabackup对数据库进行备份,所以您可以使用该软件将云数据库MySQL的备份文件恢复到自建数据库中,本文将介绍详细的操作步骤. 关于云数据库My ...
- (转载)MySQL LIKE 用法:搜索匹配字段中的指定内容
(转载)http://www.5idev.com/p-php_mysql_like.shtml MySQL LIKE 语法 LIKE 运算符用于 WHERE 表达式中,以搜索匹配字段中的指定内容,语法 ...
- 如何给wordpress首页自动显示文章内容的第一个图片
敏捷个人手机应用中使用到的数据来源于wordpress中,因为自己写的页面,所以可以自己写代码获取文章内容的第一个图片作为文章缩略图来显示,这样用户看到首页时图文并茂,感觉会好一些. 现在后台简单的使 ...
- MySQL的左连接查询,只取出最大的一条数据
今天有个需求,是通过两张表进行查询.一对多的关系.通过一个主键,取出其中的一条.开始以为还好,直接用用了left join on进行查询.却发现了问题所在.其他的好弄.开始的写法借鉴这篇博客:http ...
- hibernate 左链接查询
select pro from Provide as pro left join pro.labels as la left join pro.city as c where 1=1
随机推荐
- BugkuCTF~Mobile~WriteUp
最近,开始记录一篇关于 Android 逆向分析的 WriteUp 方便有需要的人学习,也欢迎大家相互交流, 发现不 一样的世界. 一. signin 考点:反编译.静态分析 Topic Link:h ...
- 【招聘】.NET高级开发、前端高级开发、测试工程师
.NET架构师 工作地点:厦门-湖里区 工作年限:5年及以上 学历要求:大专或以上 工资范围:15000元 - 25000元 福利待遇:五险一金,带薪年休假,年度旅游,丰富的员工团队活动:生日会.中秋 ...
- ssm(Spring、Springmvc、Mybatis)实战之淘淘商城-第一天
文章大纲 一.课程介绍二.淘淘商城基本介绍三.后台管理系统工程结构与搭建四.svn代码管理五.项目源码与资料下载六.参考文章 一.课程介绍 1. 课程大纲 一共14天课程(1)第一天:电商行业的背 ...
- USB总线标准
1.USB总线类型: OHCI(Open Host Controller Interface)是支持USB1.1的标准,但它不仅仅是针对USB,UHCI(Universal Host Controll ...
- 设计模式 | 简单工厂模式(static factory method)
按理说应该把书全都看完一遍,再开始写博客比较科学,会有比较全面的认识. 但是既然都决定要按规律更新博客了,只能看完一个设计模式写一篇了. 也算是逼自己思考了,不是看完就过,至少得把代码自己都敲一遍. ...
- 如何使用 Enterprise Architect 画 UML
本文同时发布于http://fantasylion.github.io/tools/How-to-use-EA 重识 EA (Enterprise Architect) 公司使用的 OMS 是从外面买 ...
- c/c++ 网络编程 陈硕老师视频理解之ttcp
ttcp 是干啥的:测试2台机器间的网络传输性能 wiki 功能如下图: 对应的视频是: 4.回顾基础的Sockets API.mkv 5.TTCP代码概览.mkv 6.使用TTCP进行网络传输性能测 ...
- XMPP协议之消息回执解决方案
苦恼中寻找方法 在开始做即时通信时就知道了消息回执这个概念,目的是解决通讯消息因为各种原因未送达对方而提供的一种保障机制.产生这个问题的原因主要是网络不稳定.服务器或者客户端一些异常导致没有接收到消息 ...
- 使用WSL吧
WSL(Windows Subsystem for Linux)已经装在电脑上好一阵子了,谁如果还没装的,可以看看本文,至少知道个大概,觉得有用的话知道该如何做. 简介 WSL简单说就是一个能让你在W ...
- 使用清华开源镜像安装tensorflow
安装tensorflow时,如果使用直接安装速度相对较慢,采取清华大学的镜像会提高速度.GPU版本安装方法:pip install tensorflow-gpu==1.8 -i https://pyp ...