WordPress的可拓展性初探(一)

作者:西瓜玩偶(racnil070512 at hotmail dot com) WordPress是一个时下非常流行的网络信息发布平台,它的特性之一便是极强的可拓展性。然而在这样一个工程中,它的可拓展性是从何而来的呢?下面的篇幅尝试从两个方面简单介绍WordPress的可拓展性。这两个方面不仅可以帮助我们编写WordPress的插件,同样可以帮助我们设计具有可拓展性的架构。 1. 数据库 在原版WordPress中,每一篇文章有哪些元信息(meta-data)是已经定好了的,例如一篇文章会有“作者”、“标题”、“发布时间”、“文章内容”等。这些元信息会直接体现在数据表的结构(schema)上。例如,存放文章的表中,就会有诸如“post_author”、“post_title”、“post_date”、“post_content”等列。 但是作为插件来说,我们不可避免地要为文章添加元信息。例如发布优惠券的插件需要记录优惠码、需要记录过期时间,地图插件需要记录经纬度坐标等等。元信息是灵活的,可是数据表的结构一旦定下就很难修改。那么我们怎样做才可以实现灵活的数据表结构呢? 我们可以尝试使用行列转换的思路,把原来表中的行转换成列,把原来表中的列转换成行。 在WordPress中有一个表专门用于存储文章的元信息,名称叫做 wp_postmeta 。它只有四列,分别为 meta_id 、 post_id 、 meta_key 、 meta_value 。其中 meta_id 只是一行记录唯一的ID, post_id 表示该记录属于哪一篇文章, meta_key 为元信息的名称, meta_value 为元信息的值。 下面我们用记录地理位置信息中的经纬度举一个例子。我们需要给文章存储 latitude 和 longitude 这两个信息,首先我们需要知道,我们文章的 post_id 是多少,这是可以从 wp_posts 数据表中获取的。接下来,我们要向 wp_postmeta 中添加两条记录,分别存储精度和纬度。下面以添加纬度为例(添加经度的方法类似): INSERT INTO wp_postmeta (post_id, meta_key, meta_value) VALUES (<实际的文章ID>, "latitude", <实际的纬度>); 我们可以从中发现,我们并没有对数据表的结构进行任何改动,而只是向一个表中添加了信息,就达成了扩展元信息类型的目的。 需要读取元信息的思路也很简单,只要通过 post_id 在 wp_postmeta 中找到相应的记录,并且再次根据 meta_key 进行筛选就可以了。下面举例获取纬度: SELECT meta_value FROM wp_postmeta WHERE post_id=<实际的文章ID> and meta_key="latitude"; 如果要同时获取多个信息,这样写比较紧凑: SELECT MAX(CASE WHEN pm.meta_key='latitude' THEN pm.meta_value END) AS latitude, MAX(CASE WHEN pm.meta_key='longitude' THEN pm.meta_value END) AS longitude FROM wp_posts as p, wp_postmeta as pm WHERE p.ID=pm.post_id AND p.ID=<实际的文章ID> GROUP BY p.ID; 虽然这样的设计可以极大地提高数据库的可拓展性,但是同样它也带来了一些问题: 首当其冲的是效率问题,因为这样在存储一篇文章时,就不可避免地要向两个表中添加信息,查询时也要牵扯到两个表的结合,会拖慢数据库的执行效率。 其次是类型检查,一般情况下,表中每一列都有其数据类型,在向表中插入数据时,SQL会依据数据类型对其进行检查,如果采用上面的方式,那么 meta_value 只能为字符串类型,这样从某种程度降低了数据的可靠程度。 最后是数据库结构检查,一般情况下,我们可以利用 NOT NULL 来规定某一列必须有一个值,而使用上面提到的方式,就必须由Web应用程序来进行这样的检查了。 综上所述,利用这样的方式,我们确实可以提高数据库的可拓展性,但是可拓展性也不可避免地带来一些小问题。所以我们需要根据工程的具体需求,灵活地应用这种方式。 (未完待续)

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2016-03-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

两个看似奇怪的MySQL语句问题

今天同事给了我一个文件需要更新下CMDB的数据,提供的内容是excel的形式,因为条目比较多,我需要做一些转换,批量修改成对应的SQL语句,因为只有我知道这个逻...

3247
来自专栏鸿的学习笔记

读会搜索引擎

搜索引擎一般由索引管理器,索引检索器,索引构建器,文档管理器组成。 索引管理器,顾名思义是管理带有索引结构的数据,负责对索引的访问。那么索引是怎么管理的呢?不...

681
来自专栏更流畅、简洁的软件开发方式

【自然框架】QuickPagerSQL——专门生成分页用的SQL的类库

   分享一个生成分页用SQL的函数库   一般一提到分页,大家就会想到存储过程,而大多数情况都是在存储过程里面拼接SQL,我觉得与其在存储过程里面拼接,还不如...

2295
来自专栏转载gongluck的CSDN博客

文本编辑器

文本编辑器——记事本类型的应用,可以打开、编辑、保存文本文档。可以增加单词高亮和其它的一些特性。 效果图: ? //CGEditorDlg成员 public: ...

3259
来自专栏编程坑太多

springboot(16)Shiro

1786
来自专栏Grace development

集成TP分页类代码

182
来自专栏水击三千

Silverlight学习(三)

最近对WCFRIA+MVVM+Prism有了初步的认识,能够简单的实现一些数据库的交互。这节主要讲的是Silverlight通过domainservice和ad...

2488
来自专栏跨界架构师

Aop动态生成代理类时支持带参数构造函数

  在某些情况下,我们需要植入AOP代码的类并没有默认构造函数。那么此时动态生成的代理类也需要相同签名的构造函数,并且内部调用原始类的构造函数。自己折腾了1晚上...

362
来自专栏技术点滴

Windows注册表操作基础代码

Windows注册表操作基础代码     Windows下对注册表进行操作使用的一段基础代码Reg.h: #pragma once #include<asser...

1799
来自专栏Golang语言社区

【Go 语言社区】Go实现个留言本

一、分析 要实现这个下面是几个重要的东西。 1.数据库操作(go怎么操作数据库)、 2.输出js,css,图片等 3.html显示 ...

3429

扫描关注云+社区