在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数据库中的文章内容的更多相关文章

  1. mysql数据库优化课程---12、mysql嵌套和链接查询

    mysql数据库优化课程---12.mysql嵌套和链接查询 一.总结 一句话总结:查询user表中存在的所有班级的信息? in distinct mysql> select * from cl ...

  2. 1028阿里RDS如何恢复云数据库MySQL的备份文件到自建数据库

    参照 https://help.aliyun.com/knowledge_detail/41817.html 恢复云数据库MySQL的备份文件到自建数据库 更新时间:2017-07-27 14:52: ...

  3. 如何用拉姆达表达式(Lambda Expressions) 书写左链接查询

    在C#中,如果要实现两个列表的左链接查询,我们的一般用法就是用的linq表达式就是 List<Pet> pets = }, }, } }; List<Pet2> pets2 = ...

  4. 恢复云数据库MySQL的备份文件到自建数据库遇到的报错

    报错信息 : 恢复云数据库MySQL的备份文件到自建数据库,自建数据库版本5.6.36. 按照阿里云文档操作,启动数据库报错 -- :: [ERROR] /application/mysql/bin/ ...

  5. 恢复阿里云RDS云数据库MySQL的备份文件到自建数据库

    云数据库MySQL版使用开源软件Percona Xtrabackup对数据库进行备份,所以您可以使用该软件将云数据库MySQL的备份文件恢复到自建数据库中,本文将介绍详细的操作步骤. 关于云数据库My ...

  6. (转载)MySQL LIKE 用法:搜索匹配字段中的指定内容

    (转载)http://www.5idev.com/p-php_mysql_like.shtml MySQL LIKE 语法 LIKE 运算符用于 WHERE 表达式中,以搜索匹配字段中的指定内容,语法 ...

  7. 如何给wordpress首页自动显示文章内容的第一个图片

    敏捷个人手机应用中使用到的数据来源于wordpress中,因为自己写的页面,所以可以自己写代码获取文章内容的第一个图片作为文章缩略图来显示,这样用户看到首页时图文并茂,感觉会好一些. 现在后台简单的使 ...

  8. MySQL的左连接查询,只取出最大的一条数据

    今天有个需求,是通过两张表进行查询.一对多的关系.通过一个主键,取出其中的一条.开始以为还好,直接用用了left join on进行查询.却发现了问题所在.其他的好弄.开始的写法借鉴这篇博客:http ...

  9. hibernate 左链接查询

    select pro from Provide as pro left join pro.labels as la left join pro.city as c where 1=1

随机推荐

  1. kubernetes实践之三:深入理解Pod对象

    一.Pod定义 最小部署单元 一组容器集合 一个pod中的容器共享网络命名空间 Pod是短暂的 二.Pod容器分类 基础容器 维护整个Pod的网络命名空间 初始化容器 先于业务容器开始执行,在应用启动 ...

  2. 深度学习之Numpy整理

    一.Numpy介绍.为什么要用Numpy 1.Numpy介绍 Numpy是Python的一个扩展包,语法和Matlab有很多相似之处.它支持高维数组和矩阵运算,也提供了许多数组和矩阵运算的函数.另外, ...

  3. 什么是HTML?

    在了解概念之前,先做以下操作,在桌面新建一个txt文件,然后在txt文件中输入:“Hello World”,保存该文件并将其后缀名改为.html,然后双击打开,你就能在浏览器上看到页面显示“Hello ...

  4. 产品经理之UML表达业务逻辑

    文章大纲 一. 什么是UML二. UML基础介绍三.UML实例介绍四.参考文档   一. 什么是UML   UML(Unified Modeling Language,统一建模语言) 是一种在软件设计 ...

  5. 通过命令行设置Windows 时区

    我们在进行自动测试的时候,不同的测试程序对于时区的要求不同,所以在开始的时候需要根据测试程序的要求了设置时区. Windows 提供了一个工具来进行时区设置.tzutil.exe. 目录:C:\Win ...

  6. 【死磕 Spring】----- IOC 之 注册 BeanDefinition

    原文出自:http://cmsblogs.com 获取 Document 对象后,会根据该对象和 Resource 资源对象调用 registerBeanDefinitions() 方法,开始注册 B ...

  7. 学python走过的坑 三 不能实现的浏览器缩放功能

    公司一个项目,在启动web页面时,默认应该是打开项目页面,然后浏览器启动时总是打开一个广告页面,经理让写一个脚本,让电脑每次开机自启浏览器,且加载项目页面.浏览器自启和打开项目页面轻松搞定,这时问题来 ...

  8. 从壹开始微服务 [ DDD ] 之三 ║ 简单说说:领域、子域、限界上下文

    前言 哈喽大家好,DDD领域驱动设计系列又开始了,前天周二的那篇入门文章中,也收到了一定的效果(写小说的除外),同时我也是倍感鸭梨,怎么说呢,DDD领域驱动设计已经有十年历史了,甚至更久,但是包括我在 ...

  9. 【TensorFlow篇】--Tensorflow框架实现SoftMax模型识别手写数字集

    一.前述 本文讲述用Tensorflow框架实现SoftMax模型识别手写数字集,来实现多分类. 同时对模型的保存和恢复做下示例. 二.具体原理 代码一:实现代码 #!/usr/bin/python ...

  10. 小乌龟git

    一.概念 分布式版本控制系统.诞生于Linux社区,有兴趣可以去了解下git的前世今生. 与集中式版本控制有明显区别.集中式:集中管理的服务器,保存所有的修订版本,协同工作的人通过客户端连接服务器,取 ...