热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WordPress数据库及各表结构详细解析

WordPress使用MySQL数据库。作为一个开发者,我们有必要掌握WordPress数据库的基本构造,并在自己的插件或主题中使用他们。截至WordPress3.0,WordPress一共有以下11个表。这里加上了默认的表前缀 wp_ 。wp_commentmeta:存储评论的元数

WordPress使用MySQL数据库。作为一个开发者,我们有必要掌握WordPress数据库的基本构造,并在自己的插件主题中使用他们。

截至WordPress3.0,WordPress一共有以下11个表。这里加上了默认的表前缀?wp_?。

wp_commentmeta:存储评论的元数据

wp_comments:存储评论

wp_links:存储友情链接(Blogroll)

wp_options:存储WordPress系统选项和插件、主题配置

wp_postmeta:存储文章(包括页面、上传文件、修订)的元数据

wp_posts:存储文章(包括页面、上传文件、修订)

wp_terms:存储每个目录、标签

wp_term_relationships:存储每个文章、链接和对应分类的关系

wp_term_taxonomy:存储每个目录、标签所对应的分类

wp_usermeta:存储用户的元数据

wp_users:存储用户

在WordPress的数据库结构中,存储系统选项和插件配置的wp_options表是比较独立的结构,在后文中会提到,它采用了key-value模式存储,这样做的好处是易于拓展,各个插件都可以轻松地在这里存储自己的配置。

post,comment,user 则是三个基本表加上拓展表的组合。以wp_users为例,wp_users已经存储了每个用户会用到的基本信息,比如 login_name、display_name、 password、email等常用信息,但如果我们还要存储一些不常用的数据,最好的做法不是去在表后加上一列,去破坏默认的表结构,而是将数据存在wp_usermeta中。wp_usermeta这个拓展表和wp_options表有类似的结构,我们可以在这里存储每个用户的QQ号码、手机号码、登录WordPress后台的主题选项等等。

比较难以理解的是term,即wp_terms、wp_term_relationships、wp_term_taxonomy。在WordPress的系统里,我们常见的分类有文章的分类、链接的分类,实际上还有TAG,它也是一种特殊的分类方式,我们甚至还可以创建自己的分类方法。WordPress将所有的分类及分类方法、对应结构都记录在这三个表中。wp_terms记录了每个分类的名字以及基本信息,如本站分为“WordPress开发”、“WPCEO插件”等,这里的分类指广义上的分类,所以每个TAG也是一个“分类”。wp_term_taxonomy记录了每个分类所归属的分类方法,如“WordPress开发”、“WPCEO插件”是文章分类(category),放置友情链接的“我的朋友”、“我的同事”分类属于友情链接分类(link_category)。wp_term_relationships记录了每个文章(或链接)所对应的分类方法。

庆幸的是,关于term的使用,WordPress中相关函数的使用方法还是比较清晰明了,我们就没必要纠结于它的构造了。

在上文中我们已经介绍了WordPress数据库中各个表的作用,本文将继续介绍每个表中每个列的作用。WordPress官方文档已经有比较详细的表格,本文仅对常用数据进行介绍。

wp_commentmeta

meta_id:自增唯一ID

comment_id:对应评论ID

meta_key:键名

meta_value:键值

wp_comments

comment_ID:自增唯一ID

comment_post_ID:对应文章ID

comment_author:评论者

comment_author_email:评论者邮箱

comment_author_url:评论者网址

comment_author_IP:评论者IP

comment_date:评论时间

comment_date_gmt:评论时间(GMT+0时间)

comment_content:评论正文

comment_karma:未知

comment_approved:评论是否被批准

comment_agent:评论者的USER AGENT

comment_type:评论类型(pingback/普通)

comment_parent:父评论ID

user_id:评论者用户ID(不一定存在)

wp_links

link_id:自增唯一ID

link_url:链接URL

link_name:链接标题

link_image:链接图片

link_target:链接打开方式

link_description:链接描述

link_visible:是否可见(Y/N)

link_owner:添加者用户ID

link_rating:评分等级

link_updated:未知

link_rel:XFN关系

link_notes:XFN注释

link_rss:链接RSS地址

wp_options

option_id:自增唯一ID

blog_id:博客ID,用于多用户博客,默认0

option_name:键名

option_value:键值

autoload:在WordPress载入时自动载入(yes/no)

wp_postmeta

meta_id:自增唯一ID

post_id:对应文章ID

meta_key:键名

meta_value:键值

wp_posts

ID:自增唯一ID

post_author:对应作者ID

post_date:发布时间

post_date_gmt:发布时间(GMT+0时间)

post_content:正文

post_title:标题

post_excerpt:摘录

post_status:文章状态(publish/auto-draft/inherit等)

comment_status:评论状态(open/closed)

ping_status:PING状态(open/closed)

post_password:文章密码

post_name:文章缩略名

to_ping:未知

pinged:已经PING过的链接

post_modified:修改时间

post_modified_gmt:修改时间(GMT+0时间)

post_content_filtered:未知

post_parent:父文章,主要用于PAGE

guid:未知

menu_order:排序ID

post_type:文章类型(post/page等)

post_mime_type:MIME类型

comment_count:评论总数

wp_terms

term_id:分类ID

name:分类名

slug:缩略名

term_group:未知

wp_term_relationships

object_id:对应文章ID/链接ID

term_taxonomy_id:对应分类方法ID

term_order:排序

wp_term_taxonomy

term_taxonomy_id:分类方法ID

term_id:taxonomy:分类方法(category/post_tag)

description:未知

parent:所属父分类方法ID

count:文章数统计

wp_usermeta

umeta_id:自增唯一ID

user_id:对应用户ID

meta_key:键名

meta_value:键值

wp_users

ID:自增唯一ID

user_login:登录名

user_pass:密码

user_nicename:昵称

user_email:Email

user_url:网址

user_registered:注册时间

user_activation_key:激活码

user_status:用户状态

display_name:显示名称


推荐阅读
  • 本文详细介绍了如何构建MongoDB的ReplSet复制集群,包括环境准备、配置文件设置以及初始化复制集群的具体步骤。 ... [详细]
  • Django框架的使用教程mysql数据库[三]
    Django的数据库1.在Django_test下的view.py里面model定义模型fromdjango.dbimportmodels#Createyourmodelshere ... [详细]
  • 在接手同事的项目时,发现程序虽然编译无误,但在运行时出现‘libgcc_s.so.1 must be installed for pthread_cancel to work’的错误提示。经过一系列排查与尝试,最终找到了问题的根源。 ... [详细]
  • 掌握Python岗位,你需要了解的关键技能
    最近,在社交平台脉脉上,一条关于Python岗位的消息引起了广泛关注。本文将探讨Python岗位的实际价值,并深入解析阿里巴巴等大公司在面试Python开发者时常见的问题。 ... [详细]
  • CGroups: 资源管理和控制
    CGroups(Control Groups)是Linux内核提供的一个功能,旨在限制、记录和隔离进程组使用的物理资源,如CPU、内存和I/O等。它通过精细的资源管理,支持现代容器技术如Docker的资源限制需求。 ... [详细]
  • 框图|中将_DA14531 学习笔记经验总结
    框图|中将_DA14531 学习笔记经验总结 ... [详细]
  • Kafka 示例项目中 Log4j 的配置与调试
    本文详细介绍了如何在 Kafka 源码中的示例项目配置 Log4j,以确保能够正确记录日志信息,帮助开发者更好地理解和调试代码。 ... [详细]
  • 本文探讨如何通过贪心算法有效地安排一系列活动,确保使用最少数量的会场来完成所有活动的调度。 ... [详细]
  • 本文探讨了使用匈牙利算法解决二分图中的最大权匹配问题,并通过HDU1533题目实例进行详细解析。代码实现中包括了必要的数据结构定义、输入处理以及求解过程。 ... [详细]
  • 本文详细解析了 Mongolass 中 populate 方法的正确使用方式及其限制,特别是与 Mongoose 在使用上的差异。 ... [详细]
  • Elasticsearch基础操作指南:使用Postman进行数据管理
    本文将介绍如何利用Postman工具执行基本的日志写入和数据管理操作。通过本教程,您将了解如何连接至Elasticsearch服务,创建索引,存储及检索数据。 ... [详细]
  • 统计报表模板及其实现方法
    本文介绍两个实用的统计报表模板,并提供如何将这些静态模板转换为动态JSP页面的方法。同时,文中附上了详细的代码示例。 ... [详细]
  • 解析骁龙660AIE与骁龙660的主要差异
    随着智能手机市场的不断发展,处理器技术也在不断进步。近期,一些手机开始采用骁龙660AIE处理器,这引发了消费者对其与标准版骁龙660之间差异的好奇。本文将详细探讨这两款处理器的区别,帮助您更好地了解它们各自的特点。 ... [详细]
  • 本文介绍了三款实用的Chrome插件:Gooreplacer用于加速访问依赖特定外部接口的网站;HTTP Request Blocker帮助过滤无法加载的图片请求;Browse Manager则能有效阻止恼人的弹出广告。通过合理配置这些工具,可以显著提升上网体验。 ... [详细]
  • POJ 3472 空心方格铺砖问题(高精度计算)
    题目描述:给定一个(n+1)×(n+1)的方格,其中包含一个(n-1)×(n-1)的空洞。使用1×2的砖块进行铺设,求解不同的铺设方案总数。 ... [详细]
author-avatar
糖就是甜咯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有