前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WordPress 教程:为插件自定义数据表

WordPress 教程:为插件自定义数据表

作者头像
Denis
发布2023-04-15 14:30:17
7110
发布2023-04-15 14:30:17
举报
文章被收录于专栏:WordPress果酱WordPress果酱

当你写插件的时候,你可能需要写东西到数据库中去,一般来说,有两种数据要存储,第一种是安装数据,一般存储在 wp_options 表中,使用 WordPress 的 options 机制来实现。第二种是数据,可以存储到 postmeta 表或者 usermeta 表中。如果数据特别多,就需要单独创建数据表了。这篇文章就讲讲如何在写插件时候创建数据表。

一般在写插件时候创建数据库有如下三个步骤:

  1. 创建一个添加新数据表的 PHP 函数。
  2. 保证插件启动的时候调用这个函数。
  3. 如果新版本有不同的数据表结构,创建一个升级函数。

今天我就以微信机器人 WordPress 插件高级版的 新功能:自定义文本回复,来讲解下这个过程,其中的第三步,由于没有数据库的升级不涉及。

创建一个添加新数据表的 PHP 函数

我们这个插件的安装函数叫做:weixin_robot_texts_crate_table

1. 数据库表前缀

默认 WordPress 数据库标签前缀都是 wp_,但是有人如果在一个数据库安装两个及以上 WordPress,就需要在 wp-config.php 设置 WordPress 数据库表前缀来区别,所以我们向 WordPress 数据库添加新表的时候,要先找找到数据库表前缀。我们可以在变量 $wpdb->prefix 找到。代码如下:

代码语言:javascript
复制
global $wpdb;
$table_name = $wpdb->prefix . "weixin_robot_texts";

2. 判断表是否存在

可以通过一条 SHOW TABLES SQL 查询来判断。

代码语言:javascript
复制
if($wpdb->get_var("SHOW TABLES LIKE '$table_name'") != $table_name)

3. 创建数据表

这步就是实际来创建一个数据表了。我们这个表有5个字段,id 自定义文本回复的 ID。keyword 微信发送过来的关键字,reply 自定义回复,time 添加的时间,status是否启用,有时候只是不想暂时不想启用,而不是删除。

这里我不用直接的 SQL 查询来创建,而是使用在 wp-admin/upgrade-functions.php(我们需要加载该文件,默认是不会加载的)中的 dbDeltadbDelta 函数会检查当前的表结构,和需要的表结构进行比较,所以无论添加或者修改表都会非常方便。关于具体怎样使用 dbDelta,详细可以看 wp-admin/upgrade-schema.php 中的例子。

代码语言:javascript
复制
$sql = "CREATE TABLE " . $tablename . " (
              `id` bigint(20) NOT NULL AUTO_INCREMENT,
              `keyword` varchar(255) CHARACTER SET utf8 NOT NULL,
              `reply` text CHARACTER SET utf8 NOT NULL,
              `status` int(1) NOT NULL DEFAULT '1',
              `time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
              PRIMARY KEY (`id`),
              UNIQUE KEY `keyword` (`keyword`)
            ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;
        ";
        require_once(ABSPATH . 'wp-admin/includes/upgrade.php');

最后这个 weixin_robot_texts_crate_table 函数为:

代码语言:javascript
复制
function weixin_robot_texts_crate_table() {
    global $wpdb;

    $table_name = $wpdb->prefix . "weixin_robot_texts";
    if($wpdb->get_var("show tables like '$table_name'") != $weixin_robot_texts_table) {
        $sql = "CREATE TABLE " . $table_name . " (
              `id` bigint(20) NOT NULL AUTO_INCREMENT,
              `keyword` varchar(255) CHARACTER SET utf8 NOT NULL,
              `reply` text CHARACTER SET utf8 NOT NULL,
              `status` int(1) NOT NULL DEFAULT '1',
              `time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
              PRIMARY KEY (`id`),
              UNIQUE KEY `keyword` (`keyword`)
            ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;
        ";
        require_once(ABSPATH . 'wp-admin/includes/upgrade.php');

        dbDelta($sql);
    }
}

保证插件启动的时候调用创建数据表函数

我们使用 register_activation_hook 调用上面创建数据表的函数。

代码语言:javascript
复制
register_activation_hook( __FILE__,'weixin_robot_texts_crate_table');

最后尽情期待 微信机器人 WordPress 插件高级版的 新功能:自定义文本回复。 🙂


本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 创建一个添加新数据表的 PHP 函数
  • 保证插件启动的时候调用创建数据表函数
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档