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

深入理解多站点中的WordPress数据库

在本专题前面的文章中,我为大家介绍了WordPress单站点数据库中的每个数据表,以及他们是怎么交互的、数据表之前的关系、以及他们是怎么存储的。在本文中,我们来一起看一下WordPress

在本专题前面的文章中,我为大家介绍了 WordPress 单站点数据库中的每个数据表,以及他们是怎么交互的、数据表之前的关系、以及他们是怎么存储的。在本文中,我们来一起看一下 WordPress 多站点网络中的数据库,WordPress 多站点网络中的数据库会包含一些额外的数据表,多站点网络中的每个网站都有自己独有的数据表,要理解 WordPress 数据库在多站点中的是什么样子的,我们需要了解三种类型的数据表。


  • 核心站点中的数据库

  • 整个网络的数据库

  • 网络中每个站点的数据库


多站点模式中的主站点数据库中的数据表

多站点网络中核心站点的数据库,有和单站点一样的11个数据表,这些数据表中保存这主站点中的数据:


  • wp_posts

  • wp_postmeta

  • wp_comments

  • wp_commentmeta

  • wp_users

  • wp_usermeta

  • wp_links

  • wp_term_relationships

  • wp_term_taxonomy

  • wp_terms

  • wp_options

有两个数据表和网络中的其他站点有关,他们是:


  • wp_users

  • wp_usermeta

其他数据表的工作方式和在单站点模式中一样,他们存储着主站点的内容,最后两个数据表同时存储了和整个站点有关的数据,就像只在主站点中使用的数据。

多站点模式中其他站点的数据表

除了存储多站点网络中用户数据的两个核心表,WordPress 还创建了一些关于多站点网络的附加数据表,他们包括:


  • wp_blogs

  • wp_blog_versions

  • wp_registration_log

  • wp_signups

  • wp_site

  • wp_sitemeta

  • wp_sitecategories (可选)

WordPress 使用一下7个数据表,外加两个用户数据表存储多站点中的站点数据,下面是这些数据表的简介:
























































数据表数据说明
wp_blogs这个数据表存储了站点中每个网站的信息,每个网站只有一条记录字段包括: blog_id, 域名,注册时间
wp_blog_versions当前网络的数据库版本,升级网络时会更新包括三个字段: blog_id,db_version 和 last_updated
wp_registration_log创建站点时同时创建的管理员用户对每个站点 ( 通过blog_id 定义 ),该表存储博客管理员的 user_id, email 地址和注册日期
wp_signups存储已注册但未激活的站点该数据表的每条记录包含一个唯一的 signup_id,每条记录中包含注册站点的域名、标题、用户名、和电子邮件地址,站点激活时,相应记录会自动删除
wp_site存储主站点的 URL此数据表只有一条记录,包含3个字段:主站点的站点 ID ( 一般是1 ), 主站点的域名和路径 (默认是 /)
wp_sitemeta存储多站点网络的附加信息这个数据表相当于多站点网络的wp_options 数据表,包含网络的一些设置数据,该数据表包含4个字段: meta_id, site_id (链接到 wp_blogs), meta_key 和 meta_value。
wp_sitecategories启用了全局分类时的可选数据表启用全局分类可以让每个站点中的用户使用相同的分类,该数据表包含4个字段:cat_ID,cat_name,category_nicename 和 last_updated,注意该数据表存数分类项目,不只是分类目标项目,还包括自定义分类法
wp_users所有用户的数据在这里保存而不是保存在每个站点中,因此用户可以访问整个站点中的网站在多站点网络的数据中,WordPress 在 wp_users 数据表中创建了两个附加字段: spam 和 deleted, 两个都是布尔值,默认为 NO
wp_usermeta存储站点中的用户附加信息该数据表的使用方法和单站点中的使用方法一样

数据表的关系

因为站点中每个网站的数据需要关联到站点的核心数据表,大多数数据表通过 blog_ID 链接到 wp_blogs 数据表,以下3个例外:


  • wp_sitecategories,链接文档到分类项目

  • wp_signups, 已注册未激活的网站

  • wp_usermeta, 通过 wp_users 迂回链接到 wp_blogs 数据表


WordPress多站点的数据库

多站点数据库存储每个站点的方式非常简单粗暴,直接为每个站点复制了一份数据表,因为用户数据存储在主站的数据表中,创建站点数据表时并不会复制不必要的 wp_users 和 wp_usermeta,为了区分每个不同的子站点,WordPress 为每个子站点的数据表的表名称添加了 site ID 字段,如站点2的数据表中, wp_posts 的数据表名称为 wp_2_posts,没个子站点的包含以下几个数据表。


  • wp_xx_posts

  • wp_xx_postmeta

  • wp_xx_comments

  • wp_xx_commentmeta

  • wp_xx_links

  • wp_xx_term_relationships

  • wp_xx_term_taxonomy

  • wp_xx_terms

  • wp_xx_options

上面的 xx 就是每个子站点的站点 ID,这些站点存储数据的方式都和单站点的数据存储方式一样。

总结

如果你整准备使用 WordPress 的多站点功能,详细了解一下 WordPress 多站点的数据结构是非常有必要的,这可以帮助我们更好的管理和维护一个 WordPress 多站点网络,并在出现问题时,快速定位到有问题的站点,如果WordPress 多站点中默认的数据结构不符合我们的需求,我么也可以通过 WordPress 的 Database API 增加自己的数据表。


推荐阅读
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • iOS Swift中如何实现自动登录?
    本文介绍了在iOS Swift中如何实现自动登录的方法,包括使用故事板、SWRevealViewController等技术,以及解决用户注销后重新登录自动跳转到主页的问题。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 本文主要复习了数据库的一些知识点,包括环境变量设置、表之间的引用关系等。同时介绍了一些常用的数据库命令及其使用方法,如创建数据库、查看已存在的数据库、切换数据库、创建表等操作。通过本文的学习,可以加深对数据库的理解和应用能力。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • mysql自动打开文件_让docker中的mysql启动时自动执行sql文件
    本文提要本文目的不仅仅是创建一个MySQL的镜像,而是在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动My ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文介绍了三种方法来实现在Win7系统中显示桌面的快捷方式,包括使用任务栏快速启动栏、运行命令和自己创建快捷方式的方法。具体操作步骤详细说明,并提供了保存图标的路径,方便以后使用。 ... [详细]
  • 解决.net项目中未注册“microsoft.ACE.oledb.12.0”提供程序的方法
    在开发.net项目中,通过microsoft.ACE.oledb读取excel文件信息时,报错“未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序”。本文提供了解决这个问题的方法,包括错误描述和代码示例。通过注册提供程序和修改连接字符串,可以成功读取excel文件信息。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • Postgresql备份和恢复的方法及命令行操作步骤
    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
  • 本文介绍了在使用Laravel和sqlsrv连接到SQL Server 2016时,如何在插入查询中使用输出子句,并返回所需的值。同时讨论了使用CreatedOn字段返回最近创建的行的解决方法以及使用Eloquent模型创建后,值正确插入数据库但没有返回uniqueidentifier字段的问题。最后给出了一个示例代码。 ... [详细]
author-avatar
Zh_jodie_776
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有